使用jQuery判断浏览器滚动条位置的方法


Posted in Javascript onMay 30, 2016

项目背景

webtouch(webapp)页面,防苹果手机safari浏览器,网上滑动,底部导航消失,滑动到底部又出现。向下滑动,底部导航出现。

遇到问题

1、我一开始用swipeup和swipedown来做,发现因为有滚动条,不会触发。因此只能判断滚动条是上滚下滚等。关于手机手势,后面的文章会介绍,欢迎关注!

2、通过上滚下滚来让底部导航显示或者因此,安卓上面的浏览器都可以,但是苹果safari会一闪一闪,原因是苹果safari自动有个弹跳效果,导致事件重复执行,解决办法是给上滚下滚一个距离,滚动到一定距离后返回是上滚还是下滚。

单纯判断滚动条方向

function scroll( fn ) {
  var beforeScrollTop = document.body.scrollTop,
    fn = fn || function() {};
  window.addEventListener("scroll", function() {
    var afterScrollTop = document.body.scrollTop,
      delta = afterScrollTop - beforeScrollTop;
    if( delta === 0 ) return false;
    fn( delta > 0 ? "down" : "up" );
    beforeScrollTop = afterScrollTop;
  }, false);
}

调用方法:

scroll(function(direction) { console.log(direction) });

以上方法手机苹果浏览器事件会跳动,解决方法及代码改进

scrollDirect: function (fn) {
  var beforeScrollTop = document.body.scrollTop;
  fn = fn || function () {
  };
  window.addEventListener("scroll", function (event) {
    event = event || window.event;

    var afterScrollTop = document.body.scrollTop;
    delta = afterScrollTop - beforeScrollTop;
    beforeScrollTop = afterScrollTop;

    var scrollTop = $(this).scrollTop();
    var scrollHeight = $(document).height();
    var windowHeight = $(this).height();
    if (scrollTop + windowHeight > scrollHeight - 10) { //滚动到底部执行事件
      fn('up');
      return;
    }
    if (afterScrollTop < 10 || afterScrollTop > $(document.body).height - 10) {
      fn('up');
    } else {
      if (Math.abs(delta) < 10) {
        return false;
      }
      fn(delta > 0 ? "down" : "up");
    }
  }, false);
}

调用方法:

var upflag=1;
  var downflag= 1;
  //scroll滑动,上滑和下滑只执行一次!
scrollDirect(function (direction) {
    if (direction == "down") {
      if (downflag) {
        $(".footer_wrap").slideUp(200);
        downflag = 0;
        upflag = 1;
      }
    }
    if (direction == "up") {
      if (upflag) {
        $(".footer_wrap").slideDown(200);
        downflag = 1;
        upflag = 0;
      }
    }
 });

滚动条滚动到底部和头部判断

其实我上面的函数中已经有判断,下面再列一下!看如下函数!

BottomJumpPage: function () {
      var scrollTop = $(this).scrollTop();
      var scrollHeight = $(document).height();
      var windowHeight = $(this).height();
      if (scrollTop + windowHeight == scrollHeight) { //滚动到底部执行事件
          console.dir("我到底部了");

      }
      if (scrollTop == 0) { //滚动到头部部执行事件
      console.dir("我到头部了");

      }
 }

调用方法:

$(window).scroll(BottomJumpPage);

判断div是否滚动到底部

上面的方法是判断滚动轴是否滚动到底部,但是有时候,我们在做滚动加载的时候,有时候也要做某个div是否滚动到底部然后加载。那么如何判断DIV的滚动轴滚动到底部呢?

这个也需要了解几个高度:

1、div的高度 $("#某div").height();
2、滚动轴的高度 $(#某div)[0].scrollHeight
3、滚动轴到div顶部的高度 $(某div)[0].scrollTop;
书写代码如下:

$(document).ready(function (){
    var nScrollHight = 0; //滚动距离总长(注意不是滚动条的长度)
    var nScrollTop = 0;  //滚动到的当前位置
    var nDivHight = $("#div1").height();
    $("#div1").scroll(function(){
     nScrollHight = $(this)[0].scrollHeight;
     nScrollTop = $(this)[0].scrollTop;
     if(nScrollTop + nDivHight >= nScrollHight)
      alert("滚动条到底部了");
     });
});

PS:jQuery滚动条位置控制:

将div的滚动条滚动到其子元素所在的位置,方便自动定位。

var container = $('div'), 

scrollTo = $('#row_8');


container.scrollTop( 

scrollTo.offset().top - container.offset().top + container.scrollTop() 

);


// Or you can animate the scrolling: 

container.animate({ 

scrollTop: scrollTo.offset().top - container.offset().top + container.scrollTop() 

});?

 

Javascript 相关文章推荐
js 实现css风格选择器(压缩后2KB)
Jan 12 Javascript
jquery formValidator插件ajax验证 内容不做任何修改再离开提示错误的bug解决方法
Jan 04 Javascript
向左滚动文字 js代码效果
Aug 17 Javascript
利用jquery动画特效和css打造的侧边弹出垂直导航
Apr 04 Javascript
js判断一个字符串是否包含一个子串的方法
Jan 26 Javascript
全面解析jQuery中的$(window)与$(document)的用法区别
Aug 15 jQuery
jQuery实现的表格前端排序功能示例
Sep 18 jQuery
如何封装了一个vue移动端下拉加载下一页数据的组件
Jan 06 Javascript
详解vue-cli 2.0配置文件(小结)
Jan 14 Javascript
JS图片懒加载的优点及实现原理
Jan 10 Javascript
解决Vue使用bus总线时,第一次路由跳转时数据没成功传递问题
Jul 28 Javascript
vue监听滚动事件的方法
Dec 21 Vue.js
JS检测移动端横竖屏的代码
May 30 #Javascript
BootStrap中Tab页签切换实例代码
May 30 #Javascript
js小数计算小数点后显示多位小数的实现方法
May 30 #Javascript
拥Bootstrap入怀——导航栏篇
May 30 #Javascript
基于Bootstrap实现tab标签切换效果
Apr 15 #Javascript
JavaScript编写带旋转+线条干扰的验证码脚本实例
May 30 #Javascript
Bootstrap编写导航栏和登陆框
May 30 #Javascript
You might like
亲密接触PHP之PHP语法学习笔记1
2006/12/17 PHP
开启CURL扩展,让服务器支持PHP curl函数(远程采集)
2011/03/19 PHP
在WINDOWS中设置计划任务执行PHP文件的方法
2011/12/19 PHP
使用HMAC-SHA1签名方法详解
2013/06/26 PHP
PHP时间戳 strtotime()使用方法和技巧
2013/10/29 PHP
ThinkPHP实现ajax仿官网搜索功能实例
2014/12/02 PHP
php里array_work用法实例分析
2015/07/13 PHP
学习php设计模式 php实现抽象工厂模式
2015/12/07 PHP
JavaScript 判断浏览器类型及版本
2009/02/21 Javascript
jQuery ready函数滥用分析
2011/02/16 Javascript
jQuery UI AutoComplete 使用说明
2011/06/20 Javascript
jQuery 1.7.2中getAll方法的疑惑分析
2012/05/23 Javascript
nodejs URL模块操作URL相关方法介绍
2015/03/03 NodeJs
JS实现表格数据各种搜索功能的方法
2015/03/03 Javascript
详解如何用webpack打包一个网站应用项目
2017/07/12 Javascript
详解Node 定时器
2018/02/26 Javascript
微信运维交互机器人的示例代码
2018/11/12 Javascript
Elementui表格组件+sortablejs实现行拖拽排序的示例代码
2019/08/28 Javascript
python中常用的各种数据库操作模块和连接实例
2014/05/29 Python
Python的Flask框架中实现分页功能的教程
2015/04/20 Python
Python3访问并下载网页内容的方法
2015/07/28 Python
python虚拟环境virtualenv的使用教程
2017/10/20 Python
opencv改变imshow窗口大小,窗口位置的方法
2018/04/02 Python
python生成1行四列全2矩阵的方法
2018/08/04 Python
python挖矿算力测试程序详解
2019/07/03 Python
使用Bazel编译TensorBoard教程
2020/02/15 Python
python中resample函数实现重采样和降采样代码
2020/02/25 Python
pandas分组聚合详解
2020/04/10 Python
python sitk.show()与imageJ结合使用常见的问题
2020/04/20 Python
美国内衣第一品牌:Hanes(恒适)
2016/07/29 全球购物
美国滑板店:Tactics
2020/11/08 全球购物
分厂厂长岗位职责
2013/12/29 职场文书
我爱幼儿园演讲稿
2014/09/11 职场文书
2014年依法行政工作总结
2014/11/19 职场文书
毕业生个人自荐书
2015/03/05 职场文书
MySQL中的隐藏列的具体查看
2021/09/04 MySQL