您好,欢迎来到兜白养生。
搜索
您的当前位置:首页jQuery检测div中滚动条到达底部

jQuery检测div中滚动条到达底部

来源:兜白养生


如下检测id为scroll_div滚动条到达底部事件:


 
 来自于www.manongjc.com教程
来自于www.manongjc.com教程
来自于www.manongjc.com教程

首先需要理解几个概念:
scrollHeight:表示滚动条需要滚动的高度,即内部div,10000px
scrollTop: 表示滚动条滚动的高度,可能大于外部div 500px
也就是说scrollDiv的高度+scrollTop滚动的最大高度=scrollHeight
于是检测div中div滚动条高度就简单了:

$(document).ready(function() {
 $("#scroll_div").scroll(function(){
 var divHeight = $(this).height();
 var nScrollHeight = $(this)[0].scrollHeight;
 var nScrollTop = $(this)[0].scrollTop;
 $("#input1").val(nScrollHeight);
 $("#input2").val(nScrollTop);
 $("#input3").val(divHeight);
 if(nScrollTop + divHeight >= nScrollHeight) {
 alert("到达底部了");
 }
 });
});

如果是异步加载数据,数据没加载完,又触犯了同一页的数据加载请求,我通常是加一个flag

$(document).ready(function() {
 var flag = false;
 $("#scroll_div").scroll(function(){
 
 if(flag){
 //数据加载中
 return false;
 }
 
 var divHeight = $(this).height();
 var nScrollHeight = $(this)[0].scrollHeight;
 var nScrollTop = $(this)[0].scrollTop;
 $("#input1").val(nScrollHeight);
 $("#input2").val(nScrollTop);
 $("#input3").val(divHeight);
 if(nScrollTop + divHeight >= nScrollHeight) {
 //请求数据
 flag = true;
 alert("到达底部了");
 }
 });
});

Copyright © 2019- doubailingjiu.com 版权所有

违法及侵权请联系:TEL:199 18 7713 E-MAIL:2724546146@qq.com

本站由北京市万商天勤律师事务所王兴未律师提供法律服务