jQuery移动页面开发中的触摸事件与虚拟鼠标事件简介


Posted in Javascript onDecember 03, 2015

触摸事件(touch)
在 jQuery Mobile 中有一些触摸事件是可定制的。然而,这些事件仅当与支持触摸功能的设备进行交互的用户访问您的 jQuery Mobile 网站时才可用。当这些事件可用时,您可以触发任何自定义java script 作为对五种不同的事件的响应tap、taphold、swipe、swipeleft 和 swiperight。

tap(轻击):一次快速完整的轻击后触发

taphold(轻击不放):轻击并不放(大约一秒)后触发

swipe(滑动):一秒内水平拖拽大于30PX,或者纵向拖曳小于20px的事件发生时触发的事件。多长时间拖拽多少px可以设置的。这个事件有其相关联的属性,分别为

scrollSupressionThreshold (默认: 10px) ? 水平方向拖拽大于这个值,将不触发。
durationThreshold (默认: 1000ms) ? 滑动时间超过这个数值就不会产生滑动事件。
horizontalDistanceThreshold (默认: 30px) ? 水平划动距离超过这个数值才会产生滑动事件。
verticalDistanceThreshold (默认: 75px) ? 竖直划动距离小于这个数值才会产生滑动事件。
swipeleft(左划):划动事件为向左的方向时触发

swiperight(右划):划动事件为向右的方向时触发

 

要绑定这些事件,只需要在document.ready()中进行编程即可,如下代码示例:

<!DOCTYPE HTML>
<html>
<head>
 <title>Understanding the jQuery Mobile API</title>
 <link rel="stylesheet" href="jquery.mobile.css" />
 <script src="jquery.js"></script>
 <script type="text/java script">
  $(document).ready(function(){
   $(".tap-hold-test").bind("taphold", function(event) {
    $(this).html("Tapped and held");
   }); 
  });
 </script>
 <script src="jquery.mobile.js"></script>
</head>

<body>
 <div data-role="page" id="my-page">
  <div data-role="header">
      <h1>Header</h1>
    </div>
    <div data-role="content">
      <ul data-role="listview" id="my-list">
        <li class="tap-hold-test">Tap and hold test</li>
      </ul>
  </div>
 </div>
</body>
</html>

从上面的代码可以看到,将一个list列表跟taphold事件进行了绑定,当DOM加载完毕后,当触发taphold事件后,就会显示Tapped and held的提示信息。

虚拟鼠标事件
我们提供了一系列"虚拟的"鼠标事件试图把鼠标和触摸事件抽象 出来。这使得开发者能够给一些基础的鼠标事件,例如mousedown, mousemove, mouseup, 和click来注册监听。插件会在触摸环境中,插件会保持在传统鼠标环境下触发的顺序,例如:vmouseup总是在vmousedown之前被触发,vmousedown总是在 vmouseup 之前,等等。虚拟鼠标事件也会把书剑中放出的坐标信 息标准化。所以在基于触摸的设备中事件对象的pageX, pageY, screenX, screenY, clientX, and clientY这些属性的坐标都可以用。

vmouseover:处理touch 或者 mouseover的正规化的事件

vmousedown:处理touchstart 或者 mousedown 的正规化的事件

vmousemove:处理touchmove 或者 mousemove 的正规化的事件

vmouseup:处理touchend 或者 mouseup 的正规化的事件

vclick:处理touchend 或者 鼠标点击 的正规化的事件。在基于触摸的设备上,这个事件是在vmouseup事件之后触发的。

vmousecancel:处理touch 或者 mouse 的mousecancel的正规化的事件

警告:小心使用vclick
小心在触摸设备使用vclick。Webkit内核的浏览器会在touchend事 件触发后300ms自己生成mousedown, mouseup,和click 3个事件。 这些生成的鼠标事件的目标会在他们触发的时候被计算出来,并且 是基于touch事件的位置,并且有些情况下会在不同的设备上甚至 相同设备的不同OS会导致不同的计算结果。这就意味着原始的点击 事件的目标语浏览器自己生成的鼠标事件的目标元素可能不是同一个。
我们建议在触摸后可能会改变你点击的点下面内容的事件中,使用 click而不是vclick方法。这样的事件包括页面转场和其他的一些行为比如 收缩/伸展 这样 的 可能会导致屏幕有变化或者内容完全被替换的事件。

取消一个元素默认点击的行为
应用会调用一个 vclick 事件来取消某个元素的默认点击事件。在 基于鼠标的设备上,对vclick事件调用preventDefault()方法等同 于对真实点击的时间冒泡阶段调用 preventDefault() 方法。在基 于触摸的设备上就有点复杂了,因为真实的点击事件会在vclick 事件触发300毫秒之后触发。对于触摸设备,对vclick事件调用 preventDefault()方法会一些vmouse插件的一些代码来试图捕获下 一个点击事件。所以根据上述的警告,要匹配一个触摸事件和与他 对应的鼠标事件就比较困难,因为他们的目标是不同的。所以 vmouse插件试图通过坐标来识别一个相符的点击事件通常会失败。
有些情况下两个事件的目标和坐标的识别都会失败,这样就会导致 点击事件被触发或者元素的默认动作会被执行,或者内容被改变或 者替换的情况下,触发了别的元素的点击事件。如果这样的bug在给定的元素上有规律的发生,我们建议对于动作使 用click来驱动触发。

Javascript 相关文章推荐
JavaScript 检测浏览器和操作系统的脚本
Dec 26 Javascript
浅谈JavaScript之事件绑定
Jul 08 Javascript
js实现class样式的修改、添加及删除的方法
Jan 20 Javascript
javascript实现密码验证
Nov 10 Javascript
js获取本机操作系统类型的两种方法
Dec 19 Javascript
js代码实现点击按钮出现60秒倒计时
Jan 28 Javascript
使用jQuery Rotare实现微信大转盘抽奖功能
Jun 20 Javascript
JS中parseInt()和map()用法分析
Dec 16 Javascript
JavaScript解析任意形式的json树型结构展示
Jul 23 Javascript
用js屏蔽被http劫持的浮动广告实现方法
Aug 10 Javascript
jquery ajaxfileuplod 上传文件 essyui laoding 效果【防止重复上传文件】
May 26 jQuery
浅谈如何使用webpack构建多页面应用
May 30 Javascript
详解JavaScript对象和数组
Dec 03 #Javascript
java必学必会之static关键字
Dec 03 #Javascript
详解页面滚动值scrollTop在FireFox与Chrome浏览器间的兼容问题
Dec 03 #Javascript
继续学习javascript闭包
Dec 03 #Javascript
解决js页面滚动效果scrollTop在FireFox与Chrome浏览器间的兼容问题的方法
Dec 03 #Javascript
jQuery 1.9.1源码分析系列(十五)之动画处理
Dec 03 #Javascript
ztree获取选中节点时不能进入可视区域出现BUG如何解决
Dec 03 #Javascript
You might like
PHP手机短信验证码实现流程详解
2018/05/17 PHP
php反序列化长度变化尾部字符串逃逸(0CTF-2016-piapiapia)
2020/02/15 PHP
jQuery弹出层插件简化版代码下载
2008/10/16 Javascript
javascript实现的距离现在多长时间后的一个格式化的日期
2009/10/29 Javascript
Javascript图像处理—虚拟边缘介绍及使用方法
2012/12/27 Javascript
在每个匹配元素的外部插入新元素的方法
2013/12/20 Javascript
JS/Jquery判断对象为空的方法
2015/06/11 Javascript
js拖拽的原型声明和用法总结
2016/04/04 Javascript
selenium 与 chrome 进行qq登录并发邮件操作实例详解
2017/04/06 Javascript
vue项目使用微信公众号支付总结及遇到的坑
2018/10/23 Javascript
如何通过setTimeout理解JS运行机制详解
2019/03/23 Javascript
JQuery特殊效果和链式调用操作示例
2019/05/13 jQuery
浅谈webpack和webpack-cli模块源码分析
2020/01/19 Javascript
ckeditor一键排版功能实现方法分析
2020/02/06 Javascript
JS实现判断移动端PC端功能
2020/02/21 Javascript
js节流防抖应用场景,以及在vue中节流防抖的具体实现操作
2020/09/21 Javascript
[54:43]DOTA2-DPC中国联赛 正赛 CDEC vs Dynasty BO3 第一场 2月22日
2021/03/11 DOTA
python读取json文件并将数据插入到mongodb的方法
2015/03/23 Python
基于Python函数的作用域规则和闭包(详解)
2017/11/29 Python
详解Python自建logging模块
2018/01/29 Python
python 把文件中的每一行以数组的元素放入数组中的方法
2018/04/29 Python
Python堆排序原理与实现方法详解
2018/05/11 Python
win10下python3.5.2和tensorflow安装环境搭建教程
2018/09/19 Python
Python函数中不定长参数的写法
2019/02/13 Python
使用django的objects.filter()方法匹配多个关键字的方法
2019/07/18 Python
利用 Flask 动态展示 Pyecharts 图表数据方法小结
2019/09/04 Python
python爬虫 正则表达式解析
2019/09/28 Python
Python获取、格式化当前时间日期的方法
2020/02/10 Python
python 匿名函数与三元运算学习笔记
2020/10/23 Python
美国最大的网络男装服装品牌:Bonobos
2017/05/25 全球购物
澳大利亚最好的厨具店:Kitchen Warehouse
2018/03/13 全球购物
大学生蛋糕店创业计划书
2014/01/13 职场文书
幼儿园家长会邀请函
2014/01/15 职场文书
Go 实现英尺和米的简单单位换算方式
2021/04/29 Golang
《游戏王:大师决斗》新活动上线 若无符合卡组可免费租用
2022/04/13 其他游戏
python+pyhyper实现识别图片中的车牌号思路详解
2022/12/24 Python