在页面滚动时尝试将菜单内容修复到顶部,并且当滚动时,特定滚动容器链接应该突出显示并且滚动应该是平滑的,它支持所有设备,而不会滞后。
预期当我滚动到链接2数据时,链接2菜单选项卡应该高亮,如果我点击链接,那么它也应该滚动到相应的部分。
这是我试过的:
HTML:
<div class="header_part">Header Part</div>
<div class="section_stick">
<ul>
<li><a href="#Link1">Link1</a></li>
<li><a href="#Link2">Link2</a></li>
<li><a href="#Link3">Link3</a></li>
<li><a href="#Link4">Link4</a></li>
</ul>
</div>
<div id="Link1">Link1 data</div>
<div id="Link2">Link2 data</div>
<div id="Link3">Link3 data</div>
<div id="Link4">Link4 data</div>
请帮我解决这些变化和示例演示。
答案 0 :(得分:1)
我已更新您的js以滚动到内容部分&amp;滚动时突出显示菜单项。你还需要改变你的CSS。
更新了JS
var nav = $(".section_stick");
var stickyClass = "fixed_nav";
var headerHeight = $('.header_part').height();
var content = $('#Link1, #Link2, #Link3, #Link4');
$(window).scroll(function() {
stickyMenuHandler();
activeMenuHandler();
});
function activeMenuHandler(){
content.each(function(){
if(isElementInViewport($(this))){
var _id = $(this).attr('id');
$('.section_stick a').removeClass('is-active');
$('.section_stick a[href="#' + _id +'"]').addClass('is-active');
}
});
}
function stickyMenuHandler(){
if( $(window).scrollTop() > headerHeight ) {
nav.addClass(stickyClass);
} else {
nav.removeClass(stickyClass);
}
};
nav.find('a').click(function(e){
e.preventDefault();
var targetContent = $($(this).attr('href'));
$('html, body').animate({
scrollTop: targetContent.offset().top
}, 500);
});
function isElementInViewport (el) {
if (typeof jQuery === "function" && el instanceof jQuery) {
el = el[0];
}
var rect = el.getBoundingClientRect();
return (
rect.top >= 0 &&
rect.left >= 0 &&
rect.bottom <= (window.innerHeight || document.documentElement.clientHeight) && /*or $(window).height() */
rect.right <= (window.innerWidth || document.documentElement.clientWidth) /*or $(window).width() */
);
}