dmz社区

 找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 1171|回复: 0

[心得技巧] 移动端常见问题(click 300ms延迟)

[复制链接]
  • TA的每日心情

    2024-2-20 11:15
  • 签到天数: 11 天

    [LV.3]偶尔看看II

    878

    主题

    4343

    帖子

    3995

    积分

    终身会员[A]

    Rank: 7Rank: 7Rank: 7

    积分
    3995

    发表于 2020-3-17 16:00:52 | 显示全部楼层 |阅读模式

    本站资源全部免费,回复即可查看下载地址!

    您需要 登录 才可以下载或查看,没有帐号?立即注册

    x
    根本原因:double click 双击
    移动端默认双击情况下会有方法效果,当你点击一次之后,移动端无法判断你是否下一次还会继续完成双击,因此存在300 ms 延迟

    有一部分浏览器,比如chrome浏览器,当你在meta头设置width=device-width时,它会自动禁止300 ms的延迟
    推荐的解决方法:fastclick https://github.com/ftlabs/fastclick
    原理:当检测到touchend事件后,会触发自己模拟的click事件

    先测试一下touchstart和click之间的时间差:
    我用的chrome

    [HTML] 纯文本查看 复制代码
    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>移动端动画</title>
        <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1, minimum-scale=1, user-scalable=no">
        <style>
            *{padding:0;margin:0;}
            .box{width:100px;height: 100px;background-color: pink;}
        </style>
    </head>
    <body>
        <div class="box" id="box"></div>
    
        <script>
            
            var box=document.getElementById("box"),
                startTime=0;
    
                box.addEventListener("touchstart",function(){
                    startTime=Date.now();//获取当前时间
                    console.log("touchstart");
                },false);    
    
                box.addEventListener("click",function(){
                    console.log("click");
                    console.log(Date.now()-startTime);
                },false);    
    
        </script>
    </body>
    </html>

    1888967-20200317133045553-1887805004.png

    这个88ms的时间差延迟是可以接受的,说明chrome浏览器已经解决了这个问题

    但是有部分浏览器比如安卓机上的还是会存在300ms延迟问题

    qq.png

    解决方法:首先引入fastclick.js
    [HTML] 纯文本查看 复制代码
    <script src="fastclick.js"></script>

    然后添加这段代码:

    [HTML] 纯文本查看 复制代码
    <script>[/font][/color][/align]        if ('addEventListener' in document) {
                document.addEventListener('DOMContentLoaded', function() {
                    FastClick.attach(document.body);
                }, false);
            }
        </script>

    qqq.png

    jQuery版需要用下面这段代码:

    [HTML] 纯文本查看 复制代码
    $(function() {
        FastClick.attach(document.body);
    });

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

    [HTML] 纯文本查看 复制代码
    <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



    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    QQ|Archiver|小黑屋|本站代理|dmz社区

    GMT+8, 2025-2-2 04:47 , Processed in 0.311610 second(s), 36 queries .

    Powered by Discuz! X3.4 Licensed

    Copyright © 2001-2021, Tencent Cloud.

    快速回复 返回顶部 返回列表