移动端点击延迟事件
解决方式
-
禁用缩放
<Meta name = "viewport" content="user-scalable=no" >
缺点: 网页无法缩放 -
更改默认视口宽度
<Meta name="viewport" content="width=device-width">
缺点: 需要浏览器的支持 -
css touch-action touch-action的默为 auto,将其置为 none 即可移除目标元素的 300 毫秒延迟 缺点: 新属性,可能存在浏览器兼容问题
-
tap事件 zepto的tap事件,利用touchstart和touchend来模拟click事件
缺点: 点击穿透 -
fastclick 原理: 在检测到touchend事件的时候,会通过DOM自定义事件立即出发模拟一个click事件,并把浏览器在300ms之后真正的click事件阻止掉
缺点: 脚本相对较大
使用:
//JS // 引入 <script type=‘application/javascript‘ src=‘/path/to/fastclick.js‘></script> // 使用了jquery的时候 $(function() { FastClick.attach(document.body); }); // 没使用jquery的时候 if (‘addEventListener‘ in document) { document.addEventListener(‘DOMContentLoaded‘,function() { FastClick.attach(document.body); },false);}
在vue中使用 :
//js // 安装 npm install fastclick -S // 引入 import FastClick from ‘fastclick‘ // 使用 FastClick.attach(document.body);
不需要使用fastclick的情况
以下这几种情况是不需要使用fastclick:
1、FastClick是不会对PC浏览器添加监听事件
2、Android版Chrome 32+浏览器,如果设置viewport Meta的值为width=device-width,这种情况下浏览器会马上出发点击事件,不会延迟300毫秒。
<Meta name="viewport" content="width=device-width,initial-scale=1">
3、所有版本的Android Chrome浏览器,如果设置viewport Meta的值有user-scalable=no,浏览器也是会马上出发点击事件。
4、IE11+浏览器设置了css的属性touch-action: manipulation,它会在某些标签(a,button等)禁止双击事件,IE10的为-ms-touch-action: manipulation
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。