Heim > Web-Frontend > js-Tutorial > jQuery检测div中滚动条到达底部

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

WBOY
Freigeben: 2016-06-01 09:54:10
Original
1164 Leute haben es durchsucht

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

<code class="language-html"><div id="scroll_div" style="overflow-y:auto; overflowx:hidden;margin:100px;height:500px;border:1px solid red">
   <div style="height:10000px">
        来自于www.manongjc.com教程<br>
        来自于www.manongjc.com教程<br>
        来自于www.manongjc.com教程<br>
   </div>
</div></code>
Nach dem Login kopieren

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

<code class="language-javascript">$(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("到达底部了");
        }
    });
});</code>
Nach dem Login kopieren

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

<code class="language-javascript">$(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("到达底部了");
        }
    });
});</code>
Nach dem Login kopieren

Verwandte Etiketten:
Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage