Jquery 链接的锚点位置太高

Jquery 链接的锚点位置太高,jquery,html,css,Jquery,Html,Css,您好,我有一个标题(固定)在页面顶部有多个div行。 单击按钮后,页面将使用JQuery转换到目标分区。 转换工作正常,但是div的开头在页眉后面到页面顶部。 我如何确定在何处停止向上滚动 以下是我的JQuery: $('a[href*=#]').click(function() { if (location.pathname.replace(/^\//,'') == this.pathname.replace(/^\//,'') &&

您好,我有一个标题(固定)在页面顶部有多个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;
      }
    }
  });

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

代码

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

($mainNav是您的固定导航)

脱离主题:在包装器元素上使用ID值,而不是命名锚。它允许更好的定位,是一种更现代的技术。另一个离题:如果使用CMS,请使用自定义html5属性,如“数据哈希”,而不是与ID进行比较,以便内容编辑器可以控制目标映射。