问题:做的小游戏,判断对错两人竞猜那种,左右同时点击时(双击)时发现触发了大屏上的右键事件,导致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"

如上

Logo

前往低代码交流专区

更多推荐