jQuery页面滚动不会将navbar href更改为活动类

时间:2017-02-27 08:05:21

标签: javascript jquery html css

我有一个单页的网站。当我向下滚动时,我希望我的(固定)导航栏链接在到达特定div的位置时将状态更改为活动状态。

我使用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向上滚动时,导航栏活动状态不会改变。

4 个答案:

答案 0 :(得分:2)

在这里,我为你准备小提琴,我希望你能找到它 - http://jsfiddle.net/skyr9999/dpuvcj5w

<div class="content">
    <div id="site-main">DIV Home</div>
    <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>

<nav id="main-navigation">
    <ul>
        <li><a class="menuitem" href="#site-main">Home</a></li>
        <li><a class="menuitem" href="#a">A</a></li>
        <li><a class="menuitem" href="#b">B</a></li>
        <li><a class="menuitem" href="#c">C</a></li>
        <li><a class="menuitem" href="#d">D</a></li>
    </ul>
</nav>

JS

$(document).ready(function () {

    $('a[href^="#site-main"]').addClass('active');

//smoothscroll
    $('.menuitem').on('click', function (e) {
        e.preventDefault();
        //  $(document).off("scroll");
        var athis = this;
        var target = this.hash,
                menu = target;
        $target = $(target);
        $('html, body').stop().animate({
            'scrollTop': $target.offset().top + 2
        }, 800, 'swing', function () {
            window.location.hash = target;
            $('.menuitem').removeClass('active');
            $(athis).addClass('active');

        });    
    });    

    $(window).scroll(function (event) {
        var scrollPos = $(document).scrollTop();
        if (scrollPos === 0)
        {
            $('a[href^="#site-main"]').addClass('active');
            return;
        }    
        $('.menuitem').each(function () {
            var currLink = $(this);
            var refElement = $(currLink.attr("href"));
            if (refElement.position().top <= scrollPos && refElement.position().top + refElement.height() > scrollPos) {
                $('.menuitem').removeClass("active");
                currLink.addClass("active");
            } else {
                currLink.removeClass("active");
            }
        });    
    })    
});

因为你没有包含任何css,所以我即兴发挥了一点,但看起来效果很好。

CSS

#a,#b,#c,#d,#site-main { height: 400px;}
#main-navigation {
    position: fixed;
    top: 0px;
    right:10px;        
}

#main-navigation ul li {
  display: inline;
}

.active {
  background: #f00;
}

更新1 我更新代码以匹配小提琴现在它改变菜单项选择当你scrool到项目

答案 1 :(得分:0)

您必须使用列表项循环,并使用Client = new DSClient(Server.BaseAddress.AbsoluteUri, Credential); 表示法更正ID选择器:

#

答案 2 :(得分:0)

你可以使用这个很酷的小插件来实现这一目标 https://github.com/davist11/jQuery-One-Page-Nav

当您在特定的div或部分时,它将添加当前类 希望这有帮助:)

答案 3 :(得分:0)

替换

$('a').each(function () { $(this).removeClass('active'); }) $(this).addClass('active');

$('a').each(function () {
    $(this).parent().removeClass('active');
})
$(this).parent().addClass('active');

完整代码:

$('a[href^="#"]').on('click', function (e) {
e.preventDefault();
$(document).off("scroll");

$('a').each(function () {
    $(this).parent().removeClass('active');
})
$(this).parent().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;
});

});

无需onScroll功能