解决大屏、移动端中 vue的touchStart事件及click、mouseup事件冲突问题

在开发小游戏时遇到一个问题,当双击元素时,不仅触发了touchStart事件,还意外触发了click事件。由于移动端click有300ms延迟,导致两个事件相继执行。为解决此问题,可以在touchStart事件中使用e.preventDefault()阻止click事件的默认行为。在Vue中,可以使用@touchstart.stop.prevent来简洁地处理这个问题。
摘要由CSDN通过智能技术生成

问题:做的小游戏,判断对错两人竞猜那种,左右同时点击时(双击)时发现触发了大屏上的右键事件,导致click失效。

解决:根据事件顺序touchStart是先触发的,而touchStart事件又是大屏、移动端独有的。 所以在touchStart上通过使用preventDefault方法(阻止元素默认事件行为的发生)来解决。在touchstart中添加 e.preventDefault()就可以阻止click事件触发。

今天遇到这样问题,给某个元素同时绑定touchStart及click事件后,若在移动设备上,当你点击时,会依次出发这两个事件。因为移动端设备上的click事件触发是会延迟300ms,所以touchStart事件会先触发后再触发click事件。这样导致每次都要执行两次,这样毫无意义。这里提醒下,PC是无法识别touch相

@touchstart="handleTouchStart"
@click="handleleterClick"

 handleleterClick (e) {
  console.log('click事件执行一次')
 },
 handleTouchStart (e) {
  console.log('TouchStart执行一次')
  e.preventDefault()//添加阻止click事件触发
 }

 上面这么写要写两套事件有点冗余,可以传参加标记,也可以用vue语法在html中阻止

@touchstart.stop.prevent="handleTouchStart"
@click="handleleterClick"

如上

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值