我有这个代码而且我没有从该部分的顶部识别我的h1填充,因此高亮仅在页面位置位于该h1之上时有效,而不是在该部分开始时。
$(document).ready(function () {
$(document).on("scroll", onScroll);
$('a[href^="#"]').on('click', function (e) {
e.preventDefault();
$(document).off("scroll");
$('a').each(function () {
$(this).removeClass('active');
})
$(this).addClass('active');
var target = this.hash;
$target = $(target);
$('html, body').stop().animate({
'scrollTop': $target.offset().top+2
}, 500, 'swing', function () {
window.location.hash = target;
$(document).on("scroll", onScroll);
});
});
});
function onScroll(event){
var scrollPosition = $(document).scrollTop();
$('nav a').each(function () {
var currentLink = $(this);
var refElement = $(currentLink.attr("href"));
if (refElement.position().top <= scrollPosition && refElement.position().top + refElement.outerHeight( true ) > scrollPosition) {
$('nav ul li a').removeClass("active");
currentLink.addClass("active");
}
else{
currentLink.removeClass("active");
}
});
}
我还有一个菜单动画,其中菜单会在滚动时调整大小,
但继续我的HTML
<section class="ui masthead segment" id="A ID" >
<div class="ui page grid">
<div class="column">
<img src="images/logo.png" class="ui medium image">
<div class="ui hidden transition information">
<h1 class="ui blue header">
A h1
</h1>
<p>blablabla</p>
</div>
</div>
</div>
</section>