带有平滑滚动的粘性导航正在跳跃

Posted

技术标签:

【中文标题】带有平滑滚动的粘性导航正在跳跃【英文标题】:Sticky Navigation with Smooth Scrolling is jumping 【发布时间】:2012-10-10 05:55:10 【问题描述】:

我在使用棒状导航和平滑滚动时遇到了各种各样的问题。我只是对 jQuery 了解不足,无法进行故障排除。我正在使用来自 Chris Coyer 的平滑滚动 sn-p:http://css-tricks.com/snippets/jquery/smooth-scrolling/。我的页面在这里:http://clients.ekcetera.com/agivingchance。

这是我的问题:

    对于任何导航项目,它会部分滚动,然后跳转到该位置。我很确定这是因为我不知道如何解释粘性标题,所以我将锚点放高一点以考虑锚点的高度。因此,它到达锚点并停止,然后跳转到正确的视图。 单击后退按钮时,它似乎并不总是转到正确的位置 - 有时它非常随机。我认为这与问题1有关,希望它会自行解决。我什至可以完全删除浏览器历史记录/后退按钮,但就像我说的那样,JQuery 大师还不足以知道要删除什么。

有什么建议吗?

提前致谢!

【问题讨论】:

【参考方案1】:

1. 使用来自Devin Sturgeon 的关于平滑的评论中的代码 滚动帖子。另外,我添加了一些减法来弥补 你的粘性标题。根据喜好调整。

// your functions go here 
$('a[href*=#]:not([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) 
             $('html,body').animate(
                 scrollTop: target.offset().top - 181
            , 1000);
            return false;
        
    
);

2.将所有锚点移动到您要滚动到的实际元素。

(参考:http://css-tricks.com/snippets/jquery/smooth-scrolling/#comment-197181)

【讨论】:

以上是关于带有平滑滚动的粘性导航正在跳跃的主要内容,如果未能解决你的问题,请参考以下文章

粘性导航栏可变大小更改滚动位置

在 Safari 中滚动时,粘性菜单栏“跳跃”/闪烁

位置:粘性 - 与javascript高度调整结合使用时滚动弹跳

html 粘性,平滑,主动导航

如何创建滚动后固定在顶部的粘性导航栏

CSS视差标题和粘性导航互斥?