vue项目解决移动端300ms延迟问题---------fastclick

参考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

猜你喜欢

转载自blog.csdn.net/qq_42231156/article/details/87929638