[英]How to stop follow sidebar when it reach to footer?
我有滚动条下面的侧边栏。 如果侧边栏下降到页脚,如何停止跟踪?
这是我到目前为止在这里尝试过的。
$(function() { var floatPosition = parseInt($("#left_menu").css('top')); $(window).scroll(function() { var scrollTop = $(window).scrollTop(); var newPosition = scrollTop + floatPosition + "px"; var newPosition2 = scrollTop; $("#left_menu").stop().animate({ "top" : newPosition2 }, 400); }).scroll(); });
.left_menu{position:absolute;top:0;left:0;width:100px; height:330px; margin-top: 30px; background:green} #footer { background:gray; height:100px;}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.5.0/jquery.min.js"></script> <div id="left_menu" class="left_menu">menu</div> <br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br> <div id="footer">foot</div>
请帮忙
您应该检查#left_menu
底部位置是否大于#left_menu
顶部位置, #footer
防止其增大。 请注意,您应该删除#left_menu
CSS margin-top
$(window).scroll(function() {
var scrollTop = $(window).scrollTop();
var height = $("#left_menu").height();
var top = $("#footer").offset().top;
if (scrollTop+height > top)
scrollTop = top-height;
$("#left_menu").stop().animate({
"top": scrollTop
}, 400);
}).scroll();
$(window).scroll(function() { var scrollTop = $(window).scrollTop(); var height = $("#left_menu").height(); var top = $("#footer").offset().top; if (scrollTop+height > top) scrollTop = top-height; $("#left_menu").stop().animate({ "top": scrollTop }, 400); }).scroll();
.left_menu{ position:absolute; top:0; left:0; width:100px; height:330px; background:green } #footer { background:gray; height:100px; }
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script> <div id="left_menu" class="left_menu">menu</div> <br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br> <br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br><br> <div id="footer">foot</div> <br><br><br><br><br><br><br><br>
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.