难搞的滚动事件(滚动默认,scrollTop)

关于取消默认事件

现今的 chrome 浏览器,为了实现丝滑顺畅地滑动,活动时间直接执行而不再检测默认事件,这使得无法用 e.preventDafult() 来阻止默认事件。

现在需要添加 {passive: false} 配置

$(document).addEventListener( 'scroll', fun, {passive: false} ) 把事件被动监听设置为 false 之后,就可以正常阻止默认事件了。


关于 scrollTop

为了手动地使页面平滑滚动到某个高度,需要使用 $.animate({scrollTop: val}) 。由于不同浏览器间的差异,绑定 scrollTop 的 DOM 元素是不一样的,比如

  • chrome 下最外层元素为 html ,活动事件需要绑定在这上面。

  • 而 edge 及移动端的 html 就没有高度,需要绑定在 body 节点上,才能实现滚动。

为了解决这个差异,我们需要把 animate 同时绑定在两个节点上。 $('html, body').animate()


关于获取位置

$().position() ———— 基于父元素,从自身的外边框为点。
$().offset() ———— 基于父元素,从自身内容为点。
$(window).height().width() ———— 获取窗口宽高。


记录一个底部上划继续加载的方法

因为使用的是监听 touchstar 和 touchend 方法,所以该方法只适用于移动端。

$("body").on("touchstart", getTouchS = e => {
  //记录页面当前滚动和开始Y坐标,以供比较
  startScroll = $(window).scrollTop()
  moveStartY = e.originalEvent.changedTouches[0].pageY;
});
$("body").on("touchend", getTouchE = e => {
  //这里判断是否有必要执行,没有必要则直接跳出
  if (needToDo?) return false
  //若有必要,则获取当前事件发生的状态值
  let endScroll = $(window).scrollTop(),
      ifBottom = $('body').outerHeight() - $(window).scrollTop() - $(window).height()
  //页面不再滚动 或者 leadblock位置超出范围
  if (startScroll == endScroll || ifBottom <= 0) {//滑动后没有滚动
    moveEndY = e.originalEvent.changedTouches[0].pageY,
    Y = moveEndY - moveStartY;
    if ( Y < -60 ) { //至少上滑60个单位
      //这里执行加载或之类的操作
      //*****
      //解绑事件
      $("body").off("touchstart", getTouchS)
      $("body").off("touchend", getTouchE)
    }
  }
});

主要的思路就是监听“触摸开始”和“触摸结束”两个事件,分别获取事件当前的触摸点坐标和文档滚动的值,进行对比判断“触摸是否有滑动”以及“文档是否有滚动(到底)”,来执行需要的方法。下面说说几个注意点:

  • 有必要的话,可以对事件监听添加阻止默认事件,需要在 on() 的第三个参数传入 false 。
  • 执行触摸结束监听时,优先判断是否需要执行,以节约性能。
  • 为了避免微信 iOS端底部导航栏的问题(显隐不定,出现时会减少视窗高度), $(window).height() 必须实时获取而不是用全局变量。
  • 同样为了节省性能,当执行完毕后使用 off() 对事件进行解绑,当需要传入函数名参数,所以绑定是不能使用匿名函数。

判定兼容后的阻止默认事件

var e=e||window.event;
e.stopPropagation();//阻止事件的传播(包括捕获也包括冒泡)
// 兼容处理
if (e.stopPropagation) {
    e.stopPropagation();
}else{
// IE浏览器
    e.cancelBubble=true;
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 第一部分 HTML&CSS整理答案 1. 什么是HTML5? 答:HTML5是最新的HTML标准。 注意:讲述HT...
    kismetajun阅读 27,907评论 1 45
  •   JavaScript 与 HTML 之间的交互是通过事件实现的。   事件,就是文档或浏览器窗口中发生的一些特...
    霜天晓阅读 3,581评论 1 11
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 135,253评论 19 139
  • 第13章 事件 1. 事件流 事件流描述的是从页面中接收事件的顺序。 (1) 事件冒泡 IE 的事件流叫做事件冒泡...
    yinxmm阅读 987评论 0 17
  • 没有反思的人生不值得过-苏格拉底 本周重要事件: 1.我的第一个90天践行结业,感谢自己2017年走进易效能,让我...
    安安_02a8阅读 146评论 1 1