Home > Web Front-end > JS Tutorial > jQuery detects whether scroll bar reaches bottom_jquery

jQuery detects whether scroll bar reaches bottom_jquery

WBOY
Release: 2016-05-16 15:25:35
Original
1260 people have browsed it

1. jQuery detects that the browser window scroll bar reaches the bottom
jQuery gets position and size related functions:
$(document).height() Get the height of the entire page
$(window).height() Get the current height of the part of the page that the browser can see. This size will change when you resize the browser window, which is different from the document
scrollTop() Gets the offset of the matching element relative to the top of the scroll bar.
scrollLeft() Gets the offset of the matching element relative to the left side of the scroll bar.
scroll([[data],fn]) The scroll event is triggered when the scroll bar changes
jQuery detects when the scroll bar reaches the bottom code:

$(document).ready(function() {
  $(window).scroll(function() {
 
    if ($(document).scrollTop()<=0){
      alert("滚动条已经到达顶部为0");
    }
 
    if ($(document).scrollTop() >= $(document).height() - $(window).height()) {
      alert("滚动条已经到达底部为" + $(document).scrollTop());
    }
  });
});
Copy after login

2. jQuery detects that the scroll bar in the div reaches the bottom
The first half of the article introduced jQuery's detection of the browser window scroll bar reaching the bottom. In fact, I still don't understand the concepts of scrollTop and scrollHeight. Usually the scroll bar is placed in a div.


Detect the scroll bar reaching the bottom event with id scroll_div as follows:

<div id="scroll_div" style="overflow-y:auto; overflow-x:hidden;margin:100px;height:500px;border:1px solid red">
      <div style="height:10000px">
        来自于www.jb51.net脚本之家<br>
        来自于www.jb51.net脚本之家<br>
        来自于www.jb51.net脚本之家<br>
      </div>
    </div>
Copy after login

First you need to understand a few concepts:
scrollHeight: Indicates the height that the scroll bar needs to be scrolled, that is, the internal div, 10000px
scrollTop: indicates the height of the scroll bar, which may be greater than the outer div 500px
That is to say, the height of scrollDiv + the maximum height of scrollTop = scrollHeight
So detecting the height of the div scroll bar in the div is simple:

$(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("到达底部了");
    }
  });
});
Copy after login

If the data is loaded asynchronously, the data is not loaded completely, and the data loading request of the same page is violated, I usually add a 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("到达底部了");
    }
  });
});
Copy after login

source:php.cn
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template