JS如何判断滚动条是否滚到底部

判断滚动条到底部,需要用到DOM的三个属性值,即scrollTop、clientHeight、scrollHeight。

scrollTop为滚动条在Y轴上的滚动距离。

clientHeight为内容可视区域的高度。

scrollHeight为内容可视区域的高度加上溢出(滚动)的距离。

从这个三个属性的介绍就可以看出来,滚动条到底部的条件即为scrollTop + clientHeight == scrollHeight。

代码如下(兼容不同的浏览器)。

//滚动条在Y轴上的滚动距离

function getScrollTop(){

  var scrollTop = 0, bodyScrollTop = 0, documentScrollTop = 0;

  if(document.body){

    bodyScrollTop = document.body.scrollTop;

  }

  if(document.documentElement){

    documentScrollTop = document.documentElement.scrollTop;

  }

  scrollTop = (bodyScrollTop - documentScrollTop > 0) ? bodyScrollTop : documentScrollTop;

  return scrollTop;

}

//文档的总高度

function getScrollHeight(){

  var scrollHeight = 0, bodyScrollHeight = 0, documentScrollHeight = 0;

  if(document.body){

    bodyScrollHeight = document.body.scrollHeight;

  }

  if(document.documentElement){

    documentScrollHeight = document.documentElement.scrollHeight;

  }

  scrollHeight = (bodyScrollHeight - documentScrollHeight > 0) ? bodyScrollHeight : documentScrollHeight;

  return scrollHeight;

}

//浏览器视口的高度

function getWindowHeight(){

  var windowHeight = 0;

  if(document.compatMode == "CSS1Compat"){

    windowHeight = document.documentElement.clientHeight;

  }else{

    windowHeight = document.body.clientHeight;

  }

  return windowHeight;

}

window.onscroll = function(){

  if(getScrollTop() + getWindowHeight() == getScrollHeight()){

    alert("已经到最底部了!!");

  }

};

如果用jquery来实现的话就更简单了,

$(window).scroll(function(){

  var scrollTop = $(this).scrollTop();

  var scrollHeight = $(document).height();

  var windowHeight = $(this).height();

  if(scrollTop + windowHeight == scrollHeight){

    alert("已经到最底部了!");

  }

});

如果要判断在某一个元素中的滚动条是否到底部,根据类似的思想,将document.body换成特定的元素即可,获取scrollTop和scrollHeight的方式是一样的,但是获取元素可见高度需要用到offsetHeight属性,直接依葫芦画瓢即可。

时间: 2024-10-16 03:15:20

JS如何判断滚动条是否滚到底部的相关文章

知识点:整个div而言如果判断滚动条滚动到底部

上篇文章解决的是整个document如果判断滚动条滚动到底部,那么对于文档中的div如果判断div元素滚动条滚动到底部呢? 针对这个问题,结合上文的思路,作者做了测试,经过几轮代码修正和迭代解决了这个问题. 代码如下: <div id="outer"> <div id="inner"> 90908080 </div> </div> <script type="text/javascript"&

jquery 判断滚动条到达了底部和顶端的方法

这篇文章主要介绍了jquery 判断滚动条到达了底部和到达顶端的方法,需要的朋友可以参考下 复制代码 代码如下: $(document).height()  //是获取整个页面的高度 $(window).height()  //是获取当前也就是浏览器所能看到的页面的那部分的高度.这个大小在你缩放浏览器窗口大小时会改变,与document是不一样的 要获取顶端,只需要获取到scrollTop()==0的时候就是顶端: 要获取底端,只要获取scrollTop()>=$(document).heigh

知识点:整个doucument而言如果判断滚动条滚动到底部

滚动条没有实际的高度.只是为了呈现效果才在外型上面有长度. 在js当中也没有提供滚动条的高度API. 参考了网上有关资料:判断滚动条到底部的基本逻辑是滚动条滚动的高度加上视口的高度,正好是document的高度,公式表示为 滚动条滚动的高度+浏览器视口的高度>=document的高度. 参考网上资料,具体代码如下: //滚动条在Y轴上的滚动距离 function getScrollTop() { var scrollTop = 0, bodyScrollTop = 0, documentScro

html判断滚动条是否到达底部

<%@ page language="java" contentType="text/html; charset=utf-8" pageEncoding="utf-8"%> <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"> <

js判断滚动条是否到达底部

$(document).ready(function() { var nScrollHight = 0; //滚动距离总长(注意不是滚动条的长度) var nScrollTop = 0; //滚动到的当前位置 var nDivHight = $(".datagrid-body").height();//div高度 $(".datagrid-body").scroll(function() { nScrollHight = $(this)[0].scrollHeigh

JS 原生JS 判断滚动条滑动到底部(兼容苹果safari)

ListenerScoller () { var pageIndex = 1; var startX, startY; document.addEventListener('touchstart',function (ev) { startX = ev.touches[0].pageX; startY = ev.touches[0].pageY; }, false); let _this = this; document.addEventListener('touchend',function

JS JQUERY实现滚动条自动滚到底的方法

$(function(){ var h = $(document).height()-$(window).height(); $(document).scrollTop(h); }); \ window.onload = function(){ var h = document.documentElement.scrollHeight || document.body.scrollHeight; window.scrollTo(h,h); }

JS判断滚动条到底部

form:http://www.uphtm.com/js/269.html判断滚动条到底部,需要用到DOM的三个属性值,即scrollTop.clientHeight.scrollHeight. scrollTop为滚动条在Y轴上的滚动距离. clientHeight为内容可视区域的高度. scrollHeight为内容可视区域的高度加上溢出(滚动)的距离. 从这个三个属性的介绍就可以看出来,滚动条到底部的条件即为scrollTop + clientHeight == scrollHeight.

IE,火狐,谷歌浏览器下js判断滚动条是否已拉到页面最底部

E/FF/Chrome下document.documentElement和document.body的 scrollHeight/scrollTop/clientHeight 以及判断滚动条是否已拉到页面最底部 DTD已声明 IEdocument.documentElement.scrollHeight  浏览器所有内容高度 ,document.body.scrollHeight  浏览器所有内容高度document.documentElement.scrollTop  浏览器滚动部分高度,do