私は1ページのウェブサイトを持っています。下にスクロールすると、その特定のdivの位置に到達したときに、自分の(固定された)ナビゲーションバーリンクがステータスをアクティブに変更します。jQueryのページスクロールがnavbar hrefをアクティブクラスに変更しない
jQuery
を使用しましたが、動作しません。ここに私のコードは次のとおりです。ここで
// SMOOTH SCROLLING PAGES
$(document).ready(function() {
$(document).on("scroll", onScroll);
//smoothscroll
$('a[href^="#"]').on('click', function (e) {
e.preventDefault();
$(document).off("scroll");
$('a').each(function() {
$(this).removeClass('active');
})
$(this).addClass('active');
var target = this.hash,
menu = target;
$target = $(target);
$('html, body').stop().animate({
'scrollTop': $target.offset().top+2
}, 800, 'swing', function() {
window.location.hash = target;
$(document).on("scroll", onScroll);
});
});
});
function onScroll(event){
var scrollPos = $(document).scrollTop();
$('main-navigation a').each(function() {
var currLink = $(this);
var refElement = $(currLink.attr("href"));
if (refElement.position().top <= scrollPos && refElement.position().top + refElement.height() > scrollPos) {
$('main-navigation ul li a').removeClass("active");
currLink.addClass("active");
}
else{
currLink.removeClass("active");
}
});
};
は私のHTMLです:
<nav id="main-navigation">
<ul>
<li class="active"><a href="#site-main">Home</a></li>
<li><a href="#a">A</a></li>
<li><a href="#b">B</a></li>
<li><a href="#c">C</a></li>
<li><a href="#d">D</a></li>
</ul>
</nav>
<div id="a">DIV Alpha</div>
<div id="b">DIV Bravo</div>
<div id="c">DIV Charlie</div>
<div id="d">DIV Delta</div>
スムーズスクロールは完璧に動作しますが、私はバックアップのdiv #d
からアクティブ状態が変化しないナビゲーションバー李をスクロールしたとき。
あなたの努力に感謝します。私は問題なく動作しますが、私が欠けているのは(私の場合でも)あなたが私のマウスをスクロールしてdiv divというリンクがアクティブではないと言うことです。私は両方が必要です:D – Brnovich
私のフィドルを更新します。http://jsfiddle.net/skyr9999/dpuvcj5w scroolのメニュー項目を更新しません –
ありがとう。できるだけ早くそれをチェックします! – Brnovich