ユーザーが上から一定の距離をスクロールした後にピックアップする固定メニューのあるページで作業しています。ページを下にスクロールすると、メニューからのさまざまなリンクに色を変更するクラスが与えられます。これらはすべて Chrome と Safari ではうまく機能しているように見えますが、Firefox ではページが上部でフリーズします。いくつかのコードを絶え間なくループしているかどうか疑問に思っています...本質的にウィンドウをフリーズしています。
これが私のコードです。
$.localScroll({
onBefore: function() {
$('body').data('scroll-executing', true);
},
onAfter: function() {
$('body').data('scroll-executing', false);
$(window).trigger("scroll");
}
});
$(window).scroll(function () {
if ($(this).scrollTop() > 259) {
$('.nav').addClass("f-nav");
} else {
$('.nav').removeClass("f-nav");
}
});
$(window).scroll(function() {
if ($('body').data('scroll-executing')) {
return;
}
// find the a with class 'active' and remove it
$("a").removeClass('active');
// get the amount the window has scrolled
var scroll = $(window).scrollTop();
// add the 'active' class to the correct #nav based on the scroll amount
if (scroll > 2150) {
$("#nav_3").removeClass('active');
$("#nav_5").attr('class', 'active');
setHash("contact");
} else if (scroll > 1300) {
$("#nav_2").removeClass('active');
$("#nav_3").attr('class', 'active');
setHash("portfolio");
} else if (scroll > 400) {
$("#nav_2").attr('class', 'active');
setHash("about");
} else if (scroll <= 380) { //when I remove this section, the problem goes away.
$("#nav_1").attr('class', 'active');
setHash("home");
}
});
setHash 定義を追加するのを忘れていました。ここにあります。
setHash = function(hash) {
var scrollmem = $('body').scrollTop();
window.location.hash = hash;
$('html,body').scrollTop(scrollmem);
}
また、CPU が 100% まで上昇していることにも気付きましたが、その理由がわかりません。
問題は、else if (scroll <= 380) で始まるコードの 3 番目のセクションにあります。消去法でわかりました。誰かがそれがループしている、または決して終わらない何かをしているのを見ることができますか...またはFirefoxがページの上部でフリーズする理由を説明できますか?
私はこれらすべてに慣れていません...ここ数日でjqueryを手に入れたばかりで、基本的に多くのグーグル検索を行い、必要なものに適合するようにコードを調整しています。
どんな助けでも大歓迎です。