菜单突出显示,javascript(jquery)不包括标题部分顶部填充

时间:2015-05-28 09:46:34

标签: jquery html css

我有这个代码而且我没有从该部分的顶部识别我的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>

0 个答案:

没有答案