链接锚位置太高

时间:2015-03-17 19:58:02

标签: jquery html css

您好我在页面顶部有一个标题(固定),有多个div行。 单击按钮时,页面将转换为目标div。使用JQuery。 转换工作正常,但div的开头位于页眉顶部到页面顶部。 如何确定向上滚动的位置?

这是我的JQuery:

  $('a[href*=#]').click(function() {
            if (location.pathname.replace(/^\//,'') == this.pathname.replace(/^\//,'')
            && location.hostname == this.hostname) {
              var $target = $(this.hash);
              $target = $target.length && $target
              || $('[name=' + this.hash.slice(1) +']');
              if ($target.length) {
                var targetOffset = $target.offset().top;
                $('html,body')
                .animate({scrollTop: targetOffset}, 1000);
               return false;
      }
    }
  });

1 个答案:

答案 0 :(得分:0)

由于标题是固定的,你必须考虑标题的高度,因为它现在是页面视口的一部分,而不是在文档的自然流程中:

<强>代码

$('html,body').animate({
     scrollTop: $target.offset().top - $mainNav.height()
}, 500);

($ mainNav是你的固定导航)