移动H5开发中经常用到滑动效果(页面上移、下移、向左滑动、向右滑动等),浏览器并没有内置swipe事件,可以通过touch事件(touchstart、touchmove和touchend)模拟swipe效果。jQuery mobile和zeptojs提供了swipe事件。jquery mobile只有swipeLeft和swipeRight,zeptojs提供了完整的tap和swipe事件。

  1. /**
  2. * @author accountwcx@qq.com
  3. * http://git.oschina.net/accountwcx/rhui
  4. *
  5. * swipe事件,包括swipeLeft、swipeRight、swipeUp、swipeDown。
  6. * 调用方法
  7. * Rhui.mobile.swipeLeft(el, callback, options)
  8. * Rhui.mobile.swipeRight(el, callback, options)
  9. * Rhui.mobile.swipeUp(el, callback, options)
  10. * Rhui.mobile.swipeDown(el, callback, options)
  11. * 如果使用jQuery,调用方法
  12. * $(el).rhuiSwipe('swipeLeft', callback, options);
  13. * $(el).rhuiSwipe('swipeRight', callback, options);
  14. * $(el).rhuiSwipe('swipeUp', callback, options);
  15. * $(el).rhuiSwipe('swipeDown', callback, options);
  16. */
  17. (function(window, $){
  18. var Rhui = window.Rhui || {};
  19. window.Rhui = Rhui;
  20. Rhui.mobile = (function(){
  21. var touch = {
  22. distance: 30, //滑动距离,超过该距离触发swipe事件,单位像素。
  23. duration: 1000 //滑动时长,超过该时间不触发swipe,单位毫秒。
  24. };
  25.  
  26. /**
  27. * 绑定事件
  28. * @param el 触发事件的元素
  29. * @param swipe 事件名称,可选值为swipeLeft,swipeRight,swipeUp,swipeDown
  30. * @param callback 事件回调函数
  31. * @param isStopPropagation 是否停止冒泡,true为停止冒泡
  32. * @param isPreventDefault 是否阻止默认事件,true为阻止默认事件
  33. * @param triggerOnMove swipe事件有两种触发方式,一种是在touchmove过程中,只要满足滑动距离条件即触发。
  34. * 一种是在touchend中,进入滑动距离判断,如果满足滑动距离触发。
  35. * 默认是在touchend中触发。
  36. */
  37. function bindSwipe(el, swipe, callback, triggerOnMove, isStopPropagation, isPreventDefault){
  38. var startPoint, endPoint, timer;
  39.  
  40. /**
  41. * 计算滑动方向
  42. * 首先根据x方向和y方向滑动的长度决定触发x方向还是y方向的事件。
  43. * 然后再判断具体的滑动方向。
  44. * 如果滑动距离不够长,不判断方向。
  45. */
  46. function swipeDirection(x1, y1, x2, y2){
  47. var diffX = x1 - x2,
  48. diffY = y1 - y2,
  49. absX = Math.abs(diffX),
  50. absY = Math.abs(diffY),
  51. swipe;
  52.  
  53. if(absX >= absY){
  54. if(absX >= touch.distance){
  55. swipe = diffX > 0 ? 'swipeLeft' : 'swipeRight';
  56. }
  57. }else{
  58. if(absY >= touch.distance){
  59. swipe = diffY > 0 ? 'swipeUp' : 'swipeDown';
  60. }
  61. }
  62.  
  63. return swipe;
  64. }
  65.  
  66. // 清除本次滑动数据
  67. function clearSwipe(){
  68. startPoint = undefined;
  69. endPoint = undefined;
  70.  
  71. if(timer !== undefined){
  72. clearTimeout(timer);
  73. timer = undefined;
  74. }
  75. }
  76.  
  77. /**
  78. * 判断是否符合条件,如果符合条件就执行swipe事件
  79. * @param el {HTMLElement} 元素
  80. * @param event {Event} Touch原始事件
  81. * @param return 如果执行了事件,就返回true。
  82. */
  83. function execSwipe(el, event){
  84. if(startPoint && endPoint && swipeDirection(startPoint.x, startPoint.y, endPoint.x, endPoint.y) === swipe){
  85. callback.call(el, event);
  86. return true;
  87. }
  88. }
  89.  
  90. el.addEventListener('touchstart', function(event){
  91. var self = this, touchPoint = event.touches[0];
  92.  
  93. if(isStopPropagation){
  94. event.stopPropagation();
  95. }
  96.  
  97. if(isPreventDefault){
  98. event.preventDefault();
  99. }
  100.  
  101. startPoint = {
  102. x: Math.floor(touchPoint.clientX),
  103. y: Math.floor(touchPoint.clientY)
  104. };
  105.  
  106. timer = setTimeout(function(){
  107. //如果超时,清空本次touch数据
  108. clearSwipe();
  109. }, touch.duration);
  110. });
  111.  
  112. el.addEventListener('touchmove', function(event){
  113. var self = this, touchPoint = event.touches[0];
  114.  
  115. if(isStopPropagation){
  116. event.stopPropagation();
  117. }
  118.  
  119. if(isPreventDefault){
  120. event.preventDefault();
  121. }
  122.  
  123. if(startPoint){
  124. endPoint = {
  125. x: Math.floor(touchPoint.clientX),
  126. y: Math.floor(touchPoint.clientY)
  127. };
  128.  
  129. //执行swipe事件判断,是否符合触发事件
  130. if(triggerOnMove){
  131. if(execSwipe(self, event)){
  132. clearSwipe();
  133. }
  134. }
  135. }
  136. });
  137.  
  138. el.addEventListener('touchend', function(event){
  139. if(isStopPropagation){
  140. event.stopPropagation();
  141. }
  142.  
  143. if(isPreventDefault){
  144. event.preventDefault();
  145. }
  146.  
  147. execSwipe(self, event);
  148. //清除本次touch数据
  149. clearSwipe();
  150. });
  151. }
  152.  
  153. /**
  154. * @param el {HTMLElement} HTML元素
  155. * @param callback {Function} 事件回调函数
  156. * @param options {Object} 可选参数
  157. * isStopPropagation {Boolean} 是否停止冒泡,true为停止冒泡
  158. * isPreventDefault {Boolean} 是否阻止默认事件,true为阻止默认事件
  159. * triggerOnMove {Boolean}
  160. * swipe事件有两种触发方式,一种是在touchmove过程中,只要满足滑动距离条件即触发。
  161. * 一种是在touchend中,进入滑动距离判断,如果满足滑动距离触发。
  162. * 默认值为false,在touchend中触发。
  163. */
  164. touch.swipeLeft = function(el, callback, options){
  165. if(options){
  166. bindSwipe(el, 'swipeLeft', callback, options.triggerOnMove, options.isStopPropagation, options.isPreventDefault);
  167. }else{
  168. bindSwipe(el, 'swipeLeft', callback);
  169. }
  170.  
  171. };
  172.  
  173. touch.swipeRight = function(el, callback, options){
  174. if(options){
  175. bindSwipe(el, 'swipeRight', callback, options.triggerOnMove, options.isStopPropagation, options.isPreventDefault);
  176. }else{
  177. bindSwipe(el, 'swipeRight', callback);
  178. }
  179. };
  180.  
  181. touch.swipeUp = function(el, callback, options){
  182. if(options){
  183. bindSwipe(el, 'swipeUp', callback, options.triggerOnMove, options.isStopPropagation, options.isPreventDefault);
  184. }else{
  185. bindSwipe(el, 'swipeUp', callback);
  186. }
  187. };
  188.  
  189. touch.swipeDown = function(el, callback, options){
  190. if(options){
  191. bindSwipe(el, 'swipeDown', callback, options.triggerOnMove, options.isStopPropagation, options.isPreventDefault);
  192. }else{
  193. bindSwipe(el, 'swipeDown', callback);
  194. }
  195. };
  196.  
  197. return touch;
  198. })();
  199.  
  200. // 注册jquery方法
  201. if($ && $.fn){
  202. $.fn.extend({
  203. /**
  204. * 模拟touch swipe事件,支持链式调用。
  205. * @param name {String} swipe事件名称,值有swipLeft、swipeRight、swipeUp、swipeDown。
  206. * @param callback {Function} swipe事件回调函数
  207. * @param opts {Object} 可选参数
  208. * isStopPropagation {Boolean} 是否停止冒泡,true为停止冒泡
  209. * isPreventDefault {Boolean} 是否阻止默认事件,true为阻止默认事件
  210. * triggerOnMove {Boolean} swipe事件有两种触发方式,一种是在touchmove过程中,只要满足滑动距离条件即触发。
  211. * 一种是在touchend中,进入滑动距离判断,如果满足滑动距离触发。
  212. * 默认值为false,在touchend中触发。
  213. */
  214. rhuiSwipe: function(name, callback, opts){
  215. var fnSwipe = Rhui.mobile[name];
  216.  
  217. if(this.length > 0 && fnSwipe){
  218. this.each(function(){
  219. fnSwipe(this, callback, opts);
  220. });
  221. }
  222.  
  223. return this;
  224. }
  225. });
  226. }
  227. })(window, $);

使用实例:

  1. <style type="text/css">
  2. .test{
  3. width: 400px;
  4. height: 400px;
  5. }
  6. </style>
  7. <div id="div1" class="test"></div>
  8. <div class="test"></div>
  9.  
  10. <script type="text/javascript">
  11. Rhui.mobile.swipeUp(document.getElementById('div1'), function(event){
  12. console.log(event);
  13. }, {
  14. // 可选参数
  15. isStopPropagation: true,
  16. isPreventDefault: true,
  17. triggerOnMove: true
  18. });
  19.  
  20. $('.test').rhuiSwipe('swipeLeft', function(event){
  21. console.log(event);
  22. }, {
  23. // 可选参数
  24. isStopPropagation: true,
  25. isPreventDefault: true,
  26. triggerOnMove: true
  27. });
  28. </script>

  实例展示:

  1. <style type="text/css">
  2. .test{
  3. width: 400px;
  4. height: 400px;
  5. }
  6. </style>
  7. <div id="div1" class="test"></div>
  8. <div class="test"></div>
  9.  
  10. <script type="text/javascript">
  11. Rhui.mobile.swipeUp(document.getElementById('div1'), function(event){
  12. console.log(event);
  13. }, {
  14. // 可选参数
  15. isStopPropagation: true,
  16. isPreventDefault: true,
  17. triggerOnMove: true
  18. });
  19.  
  20. $('.test').rhuiSwipe('swipeLeft', function(event){
  21. console.log(event);
  22. }, {
  23. // 可选参数
  24. isStopPropagation: true,
  25. isPreventDefault: true,
  26. triggerOnMove: true
  27. });
  28. </script>

zeptojs touch事件

zeptojs也提供了滑动事件,该滑动事件需要引用额外的touch.js。

事件 描述
tap 类似PC端浏览器的鼠标点击事件,由于移动浏览器点击事件有延迟,tap提供了无延迟的点击效果。
singleTap 效果和tap一样
doubleTap 类似PC端浏览器的鼠标双击事件
longTap 长按事件,在元素上长按超过0.75秒触发。有些浏览器有默认的长按事件,可能会被覆盖。
swipe 滑动事件,该事件不考虑滑动方向。
swipeLeft 向左滑动
swipeRight 向右滑动
swipeUp 向上滑动
swipeDown 向下滑动
实例展示:
  1. <style>.delete { display: none; }</style>
  2.  
  3. <ul id=items>
  4. <li>List item 1 <span class=delete>DELETE</span></li>
  5. <li>List item 2 <span class=delete>DELETE</span></li>
  6. </ul>
  7.  
  8. <script>
  9. // show delete buttons on swipe
  10. $('#items li').swipe(function(){
  11. $('.delete').hide()
  12. $('.delete', this).show()
  13. })
  14.  
  15. // delete row on tapping delete button
  16. $('.delete').tap(function(){
  17. $(this).parent('li').remove()
  18. })
  19. </script>

本文摘自死神的丧钟 http://blog.csdn.net/accountwcx/article/details/49334091

HTML5滑动(swipe)事件的更多相关文章

  1. 移动端 之 触摸事件、Tap事件和swipe事件

    触摸事件 touch是一个事件组,意思不止一个事件,是移动端滑动事件组,touchstart touchmove touchend touchcancel touchstart 当刚刚触摸屏幕的时候触 ...

  2. H5案例分享:html5重力感应事件

    html5重力感应事件 一.手机重力感应图形分析 1.设备围绕z轴的旋转角度为α,α角度的取值范围在[0,360). 设备在初始位置,与地球(XYZ)和身体(XYZ)某个位置对齐. 设备围绕z轴的旋转 ...

  3. Zepto中的Swipe事件失效

    需要阻止浏览器默认滑动的事件 document.addEventListener('touchmove', function (event) { event.preventDefault(); }, ...

  4. html5重力感应事件之DeviceMotionEvent

    前言 今天主要介绍一下html5重力感应事件之DeviceMotionEvent,之前我的一篇文章http://www.haorooms.com/post/jquery_jGestures, 介绍了第 ...

  5. HTML5服务器发送事件(Server-Send Events)

    HTML5服务器发送事件是允许获得来自服务器的更新. server-sent事件-单向传递消息,表示网页自动获取来自服务器的更新. 其中有一个重要的对象,eventsource对象是用来接收服务器发送 ...

  6. HTML5 服务器发送事件(Server-Sent Events)

    沈阳SEO:HTML5 服务器发送事件(server-sent event)允许网页获得来自服务器的更新. Server-Sent 事件 - 单向消息传递 Server-Sent 事件指的是网页自动获 ...

  7. HTML5: HTML5 服务器发送事件(Server-Sent Events)

    ylbtech-HTML5: HTML5 服务器发送事件(Server-Sent Events) 1.返回顶部 1. HTML5 服务器发送事件(Server-Sent Events) HTML5 服 ...

  8. js监听网页页面滑动滚动事件,实现导航栏自动显示或隐藏

    /** * 页面滑动滚动事件 * @param e *///0为隐藏,1为显示var s = 1;function scrollFunc(e) { // e存在就用e不存在就用windon.event ...

  9. html5滑动事件代码

    $(".header").on("touchstart", function(e) { // 判断默认行为是否可以被禁用 if (e.cancelable) { ...

随机推荐

  1. python入门到精通[三]:基础学习(2)

    摘要:Python基础学习:列表.元组.字典.函数.序列化.正则.模块. 上一节学习了字符串.流程控制.文件及目录操作,这节介绍下列表.元组.字典.函数.序列化.正则.模块. 1.列表 python中 ...

  2. 【进展】LL谱面存储方式的改善

    今天得某位高人相助,获得了一堆LL里面的标准谱面文件,是json格式的.于是折腾了一下午加一晚上,总算让SLP正确解析了json格式的谱面.

  3. 改变this指针的apply,call,bind的区别

    apply.call 在 javascript 中,call 和 apply 都是为了改变某个函数运行时的上下文(context)而存在的,换句话说,就是为了改变函数体内部 this 的指向. Jav ...

  4. 批处理——服务器的web文件备份

    首先建立三个文本文件,稍后会变成.bat结尾的批处理文件. 第一个文件:copyfile.bat[复制需要备份的文件到tmp文件下,等待压缩时使用] xcopy "D:\Webhost\*. ...

  5. tp

    ThinkPHP php框架 真实项目开发步骤: 多人同时开发项目,协作开发项目.分工合理.效率有提高(代码风格不一样.分工不好) 测试阶段 上线运行 对项目进行维护.修改.升级(单个人维护项目,十分 ...

  6. 图片轮播器bcastr4.swf“&”符号的问题

    bcastr4.swf是一个很不错的网页图片轮播器,我一直使用它作为网站首页图片轮播的控件. http://xiaogui.org/bcastr-open-source-flash-image-sil ...

  7. 未能加载文件或程序集“projectname, Version=1.0.0.0, Culture=neutral, PublicKeyToken=null”或它的某一个依赖项。系统找不到指定的文件。

  8. c#控制台調用SSIS包互传值

    有时候不仅仅需要在内部执行package包,多数情况下,是需要在外部进行调用,比如,需要一个批处理或者控制台程序进行外部调用SSIS包,而往往这个包所配置的连接字符串是经过加密处理的,所以当外部调用S ...

  9. php常用函数file

    fopen:(创建并)打开一个文件或url地址. 模式 说明 r 只读,将将文件指针指向文件开始位置 r+ 读写,将文件指针指向文件开始位置 w 只写,将文件指针指向文件开始位置将将文件内容清空,如果 ...

  10. ubuntu安装cpu版caffe

    最近在笔记本上配置了ubuntu14.04,并配置了caffe,整个过程大概花了2个小时. 希望在安装时能给大家一个启发,这里配置的是无gpu版的,因为我的笔记本时核心显卡,配置gpu版的要编译cud ...