admin 发表于 2013-8-8 19:26:21

jquery mobile 虚拟鼠标事件

      我们提供了一系列"虚拟的"鼠标事件试图把鼠标和触摸事件抽象 出来。这使得开发者能够给一些基础的鼠标事件,例如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来驱动触发。

admin 发表于 2013-9-27 19:24:56

学习了,不错,讲的太有道理了

uqobk8216 发表于 2013-10-1 16:20:55

路过,支持一下啦

小雪 发表于 2013-10-4 04:57:36

写的真的很不错

phonegap100 发表于 2013-10-5 18:56:01

有竞争才有进步嘛

小雪 发表于 2013-10-7 09:59:25

没看完~~~~~~ 先顶,好同志

phonegap100 发表于 2013-10-9 02:40:33

不知该说些什么。。。。。。就是谢谢
页: [1]
查看完整版本: jquery mobile 虚拟鼠标事件