0

我正在使用以下 Java 将菜单粘贴到页面顶部:

jQuery("document").ready(function($){
    var nav = $('.nav-container');
    $(window).scroll(function () {
        if ($(this).scrollTop() > 205) {
            nav.css({
                position: 'fixed',
                top: 0,
                margin: '0px',
                left: nav.offset().left,
                width: nav.width()
            });
        } else {
            nav.css({
                position: 'static',
                margin: '115px 0 0 0'
            });
        }
    });
});

Java 的功能在除 Chrome 之外的所有浏览器中都能完美运行。在 Chrome 中,当您向下滚动和备份时,它会创建一个“幽灵”菜单。你可以在这里看到它:双人菜单的定制花店。您可以在此处查看该网站:The Bespoke Florist。我已经在三台不同的机器上复制了这个问题,但它似乎只适用于 Chrome。非常感谢任何帮助。

4

1 回答 1

0

很抱歉回答我自己的问题。Chrome 的问题在于对屏幕上的像素进行硬编码。转到动态 Div 测试,它可以正常工作。这是我更新的代码!

    <script>
  jQuery("document").ready(function($){
    var nav = $('.nav-container'),
        navOff  = nav.offset();
    $(window).scroll(function () {
        if ($(this).scrollTop() > navOff.top) {
            nav.css({
                position: 'fixed',
                top: 0,
                margin: '0px',
                left: nav.offset().left,
                width: nav.width()
            });
        } else {
            nav.css({
                position: 'static',
                margin: '115px 0 0 0'
            });
        }
    });
});
</script>
于 2013-11-08T15:42:30.810 回答