Touch Repeat Directive
类星体提供了功能齐全的 Vue 指令,可以完全取代像Hammerjs
这样的库:v-touch-pan
, v-touch-swipe
, v-touch-hold
,甚至v-touch-repeat
。
这些指令不仅可以处理鼠标事件,还可以处理触摸事件,所以您可以用它们在您的 App 中完成一些很酷的事情。
下面我们将讲述v-touch-repeat
指令
Vue 指令,当用户触摸并按住一个组件或元素时,在指定的时间间隔内触发一个事件。
TouchRepeat API
用法
在下面的区域中,点击鼠标/点击屏幕后按住,然后查看页面的变化,注意,在有触摸功能的设备上,页面滚动会被禁用。
默认的重复模式是 0:600:300(毫秒)。
下面的示例中,配置了也对SPACE
, ENTER
和 h
按键做出反应(请先关注此处),使用 0:300:200 (ms) 重复模式。热键,点击/触摸,然后保持住。
下面的示例中,将 TouchRepeat 应用在了 QBtn 上,注意指令的参数是如何使得蓝色的按钮加速慢于红色按钮的。
处理鼠标事件
当您想处理鼠标事件时,使用mouse
修饰符:
<div v-touch-repeat.mouse="myHandler">...</div>
处理按键事件
当您也想处理按键事件时,使用 keycodes 作为修饰符:
<div v-touch-repeat.65.70="myHandler">...</div>
对于按键,也有一些特殊的修饰符,可使用直观的字符串代替等效的 keycode: space
, tab
, enter
。
Inhibiting TouchRepeat
您可以通过阻止内部元素touchstart
/mousedown
/keydown
事件的冒泡行为来抑制 TouchRepeat 事件:
<div v-touch-repeat.mouse.enter="userHasHold">
<!-- ...content -->
<div @touchstart.stop @mousedown.stop @keydown.stop>
<!--
TouchRepeat 事件不会应用到这里, 因为我们
在 touchstart,keydomn 和 mousedown 事件上
调用了 stopPropagation()
-->
</div>
<!-- ...content -->
</div>
然而,若您使用capture
,keyCapture
或者 mouseCapture
修饰符,则事件会先到达 TouchRepeat 指令,然后才是内部元素,所以 TouchRepeat 事件仍然会被触发。
注意热更新相关
由于性能的原因,不是所有的修饰符都是 reactive 的,有一些需要刷新页面才能更新,请在 API 卡片中检查的哪些修饰符不具备 reactive。