使用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 相关文章推荐
JavaScript 继承详解(一)
Jul 13 Javascript
JavaScript中原型和原型链详解
Feb 11 Javascript
JS基于Mootools实现的个性菜单效果代码
Oct 21 Javascript
深入剖析JavaScript编程中的对象概念
Oct 21 Javascript
轻量级jQuery插件slideBox实现带底栏轮播(焦点图)代码
Mar 28 Javascript
vue分页组件table-pagebar使用实例解析
Nov 15 Javascript
jQuery实现页面点击后退弹出提示框的方法
Aug 24 Javascript
使用jquery实现的循环连续可停顿滚动实例
Nov 23 Javascript
Kotlin学习第一步 kotlin语法特性
May 25 Javascript
详解微信小程序Radio选中样式切换
Jul 06 Javascript
使用vue-cli导入Element UI组件的方法
May 16 Javascript
element-ui upload组件多文件上传的示例代码
Oct 17 Javascript
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中设置多级目录session的问题
2011/08/08 PHP
PHP实现提取一个图像文件并在浏览器上显示的代码
2012/10/06 PHP
利用PHP函数计算中英文字符串长度的方法
2014/11/11 PHP
WordPress迁移时一些常见问题的解决方法整理
2015/11/24 PHP
PHP中抽象类、接口的区别与选择分析
2016/03/29 PHP
JQuery拖拽元素改变大小尺寸实现代码
2012/12/10 Javascript
jqGrid随窗口大小变化自适应大小的示例代码
2013/12/28 Javascript
js获取url中&quot;?&quot;后面的字串方法
2014/05/15 Javascript
javascript实现控制的多级下拉菜单
2015/07/05 Javascript
bootstrap实现弹窗和拖动效果
2016/01/03 Javascript
canvas绘制七巧板
2017/02/03 Javascript
微信小程序 列表的上拉加载和下拉刷新的实现
2017/04/01 Javascript
vue 自定义 select内置组件
2018/04/10 Javascript
JS实现快递单打印功能【推荐】
2018/06/21 Javascript
微信小程序定位当前城市的方法
2018/07/19 Javascript
微信小程序 scroll-view 实现锚点跳转功能
2019/12/12 Javascript
[46:28]EG vs Liquid 2019国际邀请赛淘汰赛 败者组 BO3 第二场 8.23
2019/09/05 DOTA
python基础教程之python消息摘要算法使用示例
2014/02/10 Python
Win7下搭建python开发环境图文教程(安装Python、pip、解释器)
2016/05/17 Python
python 自动化将markdown文件转成html文件的方法
2016/09/23 Python
python通过opencv实现批量剪切图片
2017/11/13 Python
在IPython中进行Python程序执行时间的测量方法
2018/11/01 Python
Python设计模式之原型模式实例详解
2019/01/18 Python
对python周期性定时器的示例详解
2019/02/19 Python
python中必要的名词解释
2019/11/20 Python
python计算Content-MD5并获取文件的Content-MD5值方式
2020/04/03 Python
python 使用多线程创建一个Buffer缓存器的实现思路
2020/07/02 Python
HTML5实现Notification API桌面通知功能
2016/03/02 HTML / CSS
浅谈HTML5 &amp; CSS3的新交互特性
2016/07/19 HTML / CSS
2019史上最全Database工程师题库
2015/12/06 面试题
linux比较文件内容的命令是什么
2013/03/04 面试题
预备党员党校学习自我评价分享
2013/11/12 职场文书
2015年元旦文艺汇演主持词
2014/03/26 职场文书
建筑安全生产目标责任书
2014/07/23 职场文书
JavaScript中的宏任务和微任务详情
2021/11/27 Javascript
Python之Matplotlib绘制热力图和面积图
2022/04/13 Python