参考github:https://github.com/ftlabs/fastclick。
1. 下载:npm install --save fastclick。
2. 引入:在main.js文件中:这样就解决了在移动端body下元素点击300ms延迟的问题
import fastclick from "fastclick"
fastclick.attach(document.body)
3. 原理:在检测到touchend事件的时候,会通过DOM自定义事件立即出发模拟一个click事件,并把浏览器在300ms之后真正的click事件阻止掉。
4. 以下这几种情况是不需要使用fastclick:
4.1、FastClick是不会对PC浏览器添加监听事件。
4.2、Android版Chrome 32+浏览器,如果设置viewport meta的值为width=device-width,这种情况下浏览器会马上出发点击事件,不会延迟300毫秒。
<meta name="viewport" content="width=device-width, initial-scale=1">
4.3、所有版本的Android Chrome浏览器,如果设置viewport meta的值有user-scalable=no,浏览器也是会马上出发点击事件。
4.4、IE11+浏览器设置了css的属性touch-action: manipulation,它会在某些标签(a,button等)禁止双击事件,IE10的为-ms-touch-action: manipulation