移动端300s延迟

300ms延时问题

移动设备上的浏览器默认会在用户点击屏幕大约延迟300毫秒后才会触发点击事件,这是为了检查用户是否在做双击。
那么如何解决这个问题呢?我使用的是fastclick.js
参考:https://github.com/ftlabs/fastclick

FastClick的使用

安装fastclick
安装fastclick可以使用npm,Component和Bower。另外也提供了Ruby版的gem fastclick-rails以及.NET提供了NuGet package。最直接的可以在页面引入fastclick js文件。如:
在页面直接引入fastclick.js


使用npm安装

npm install fastclick

初始化FastClick实例
初始化FastClick实例建议在页面的DOM文档加载完成后。

纯Javascript版

if ('addEventListener' in document) {
    document.addEventListener('DOMContentLoaded', function() {
        FastClick.attach(document.body);
    }, false);
}

jQuery版

$(function() {
    FastClick.attach(document.body);
});

类似Common JS的模块系统方式

var attachFastClick = require('fastclick');
attachFastClick(document.body);
调用require('fastclick')会返回FastClick.attach函数。

使用needsclick过滤特定的元素
如果页面上有一些特定的元素不需要使用fastclick来立刻触发点击事件,可以在元素的class上添加needsclick:

Ignored by FastClick

实例如下:



  
    
    
    
  
  
    

A层对点击事件的响应正常,在iOS上会导致300毫秒的延迟。

B层通过FastClick增强,并将毫不延迟地启动click处理程序。

这些层将在不支持触摸事件的平台上正常工作。

Touch end time:

Click event time:

Difference:

A
B

使用ipone6/7/8测试结果如下
先点击A
移动端300s延迟_第1张图片
再点击B
移动端300s延迟_第2张图片

不需要使用fastclick的情况

以下这几种情况是不需要使用fastclick:
1、FastClick是不会对PC浏览器添加监听事件
2、Android版Chrome 32+浏览器,如果设置viewport meta的值为width=device-width,这种情况下浏览器会马上出发点击事件,不会延迟300毫秒。


3、所有版本的Android Chrome浏览器,如果设置viewport meta的值有user-scalable=no,浏览器也是会马上出发点击事件。
4、IE11+浏览器设置了css的属性touch-action: manipulation,它会在某些标签(a,button等)禁止双击事件,IE10的为-ms-touch-action: manipulation

你可能感兴趣的:(前端技术,网页优化)