如何解决Vue中touchStart事件与click事件冲突的终极方法?

2026-04-03 00:100阅读0评论SEO资源
  • 内容介绍
  • 文章标签
  • 相关推荐

本文共计531个文字,预计阅读时间需要3分钟。

如何解决Vue中touchStart事件与click事件冲突的终极方法?

一、问题:今天遇到这样一个问题,给某个元素同时绑定touchStart及click事件后,在移动设备上,当你点击时,会依次触发这两个事件。因为移动端设备上的click事件触发起来会延迟300ms,所以导致这样的现象。

一 、问题:

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

二、解决方式

(1)preventDefault方法

通过使用preventDefault方法(阻止元素默认事件行为的发生)来解决。在touchstart中添加 e.preventDefault()就可以阻止click事件触发。

阅读全文

本文共计531个文字,预计阅读时间需要3分钟。

如何解决Vue中touchStart事件与click事件冲突的终极方法?

一、问题:今天遇到这样一个问题,给某个元素同时绑定touchStart及click事件后,在移动设备上,当你点击时,会依次触发这两个事件。因为移动端设备上的click事件触发起来会延迟300ms,所以导致这样的现象。

一 、问题:

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

二、解决方式

(1)preventDefault方法

通过使用preventDefault方法(阻止元素默认事件行为的发生)来解决。在touchstart中添加 e.preventDefault()就可以阻止click事件触发。

阅读全文