0

我正在开发一个滚动到侧面的网站,并且我使用固定位置将菜单保持在顶部,但我意识到当我向下滚动时,菜单也会向下滚动。我想知道当我滚动到侧面时是否有办法将菜单保持在顶部,但是当我向下滚动时它不会下降。

所以我尝试使用相对于身体的绝对位置,但是当我侧滚动时,这并没有使菜单保持在顶部。

#menu
{   
background          : url(images/banner5.gif) no-repeat;
height              : 60px;
margin-top          : 20px;
position            : absolute; 
left                : 450px;
}

#menuFloat li
{   
display             : inline;
float               : left; 
padding             : 8px 20px 0px 30px;
}

#menuFloat li a
{   
    color               : #9d0c10;
    font-family         : Erato;
    font-size           : 12pt;
    font-style          : italic;
    text-decoration     : none; 
}

$(document).ready(function() {
 $("#menuFloat a").bind("click",function(event){ event.preventDefault();
  var target = $(this).attr("href");
   $("html, body").stop().animate({ scrollLeft: $(target).offset().left, scrollTop:    $(target).offset().top }, 1200);
 }); }); 

<div id="menu">
    <ul id="menuFloat">
        <li><a class="nav1" href="#nav1">Home</a></li>
        <li><a class="nav2" href="#nav2">About Us</a></li>
        <li><a class="nav3" href="#nav3">Members</a></li>
        <li><a class="nav4" href="#nav4">Events</a></li>
        <li><a class="nav5" href="#nav5">Media</a></li>
        <li><a class="nav6" href="#nav6">Contact Us</a></li>    
    </ul>
</div>

第一部分是菜单的 CSS,第二部分是关于如何水平滑动的 jquery 代码,第三部分是菜单的 html。

如果您对我的问题感到困惑,请在此处查看:http: //permika-montreal.tk/new.php 当您向下滚动时,您会看到菜单也是如此,我希望不要发生这种情况。

4

2 回答 2

2

您可以通过left在用户使用 JavaScript/jQuery 水平滚动时更新 CSS 属性来完成此操作。

请参阅:https ://stackoverflow.com/a/9423822/1718121

$(window).scroll(function(event) {
  var x = $(this).scrollLeft();
  $("#menu").css("left", x + offset); //Change offset to be the default margin-left of your menu.
}
于 2013-02-02T23:05:57.913 回答
1

看这里

#menu
{   
background          : url(images/banner5.gif) no-repeat;
height              : 60px;
top                 : 20px;
position            : absolute; 
left                : 50px;
}

jQuery

$(document).ready(function(){

 var lastScrollLeft = 0;
$(window).scroll(function() {
    var documentScrollLeft = $(document).scrollLeft();
    if (lastScrollLeft != documentScrollLeft) {
        console.log('scroll x');
        lastScrollLeft = documentScrollLeft;
        $("#menu").css("left", lastScrollLeft+50);

    }
});   

});
于 2013-02-02T23:36:56.163 回答