使用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获取url参数的使用扩展实例
Dec 29 Javascript
也说JavaScript中String类的replace函数
Sep 22 Javascript
JavaScript 更严格的相等 [译]
Sep 20 Javascript
js判断字符长度及中英文数字等
Mar 19 Javascript
JavaScript第一篇之实现按钮全选、功能
Aug 21 Javascript
Bootstrap的modal拖动效果
Dec 25 Javascript
jQuery实现滚动条滚动到子元素位置(方便定位)
Jan 08 Javascript
ionic环境配置及问题详解
Jun 27 Javascript
vue2使用keep-alive缓存多层列表页的方法
Sep 21 Javascript
微信小程序实现发送模板消息功能示例【通过openid推送消息给用户】
May 05 Javascript
利用Vue-draggable组件实现Vue项目中表格内容的拖拽排序
Jun 07 Javascript
JavaScript圣杯布局与双飞翼布局实现案例详解
Aug 05 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 批量替换程序的具体实现代码
2013/10/04 PHP
8个PHP数组面试题
2015/06/23 PHP
PHP yield关键字功能与用法分析
2019/01/03 PHP
Laravel 手动开关 Eloquent 修改器的操作方法
2019/12/30 PHP
Json对象替换字符串占位符实现代码
2010/11/17 Javascript
JavaScript window.document的属性、方法和事件小结
2012/10/24 Javascript
JavaScript面试开发常用的知识点总结
2016/08/08 Javascript
利用JS实现简单的日期选择插件
2017/01/23 Javascript
assert()函数用法总结(推荐)
2017/01/25 Javascript
vue.js之vue-cli脚手架的搭建详解
2017/05/05 Javascript
javascript将list转换成树状结构的实例
2017/09/08 Javascript
JS简单实现数组去重的方法分析
2017/10/14 Javascript
Angular 封装并发布组件的方法示例
2018/04/19 Javascript
解决vue.js 数据渲染成功仍报错的问题
2018/08/25 Javascript
vuex 实现getter值赋值给vue组件里的data示例
2019/11/05 Javascript
详解webpack-dev-middleware 源码解读
2020/03/23 Javascript
详解vue 组件
2020/06/11 Javascript
在Python中进行自动化单元测试的教程
2015/04/15 Python
python通过文件头判断文件类型
2015/10/30 Python
用python实现刷点击率的示例代码
2019/02/21 Python
Python获取浏览器窗口句柄过程解析
2020/07/25 Python
Pycharm2020.1安装中文语言插件的详细教程(不需要汉化)
2020/08/07 Python
python简单利用字典破解zip文件口令
2020/09/07 Python
python 实现一个图形界面的汇率计算器
2020/11/09 Python
一个基于canvas的移动端图片编辑器的实现
2020/10/28 HTML / CSS
科颜氏英国官网:Kiehl’s英国
2019/11/20 全球购物
乌克兰品牌化妆品和香水在线商店:Bomond
2020/01/14 全球购物
英国在线定做百叶窗网站:Make My Blinds
2020/08/17 全球购物
介绍一下常见的木马种类
2014/11/15 面试题
大学生职业生涯规划书参考模板
2014/03/05 职场文书
学习计划书怎么写
2014/09/15 职场文书
党的群众路线教育实践活动心得体会(医院)
2014/11/03 职场文书
给朋友的道歉短信
2015/05/12 职场文书
人民的好儿女观后感
2015/06/18 职场文书
公务员廉洁从政心得体会
2016/01/19 职场文书
初一数学教学反思
2016/02/17 职场文书