美文网首页
你知道的移动端事件可能过时了。。。

你知道的移动端事件可能过时了。。。

作者: 捡了幸福的猪 | 来源:发表于2019-09-25 14:24 被阅读0次

一直以为移动端点击事件会有300ms的延迟,原来只是我觉得,不应该要我觉得[捂脸]

1) 为啥移动端会有click延迟的说法?
谷歌开发者文档 300ms tap delay, gone away

For many years, mobile browsers applied a 300-350ms delay between touchend and click while they waited to see if this was going to be a double-tap or not, since double-tap was a gesture to zoom into text.

即 移动端要判断是否是双击,所以单击之后不能够立刻触发click,要等300ms,直到确认不是双击了才触发click。所以就导致了click有延迟。

这是移动端浏览器的默认行为,包括双击缩放、双击滚动。这些行为,尤其是双击缩放,主要是为桌面网站在移动端的浏览体验设计的。而在用户对页面进行操作的时候,移动端浏览器会优先判断用户是否要触发默认的行为。

2)现在还有吗?

答:可以没有了。

在2014年的Chrome 32版本已经把这个延迟去掉了,如果有一个meta标签:

  <meta name="viewport" content="width=device-width">

即把viewport设置成设备的实际像素,那么就不会有这300ms的延迟,并且这个举动受到了IE/Firefox/Safari(IOS 9.3)的支持,也就是说现在的移动端开发可以不用顾虑click会比较迟钝的问题。

如果设置initial-scale=1.0,在chrome上是可以生效,但是Safari不会:

  <meta name**=**"viewport" content**=**"initial-scale=1.0">

还有第三种办法就是设置CSS:

 html{

      touch-action: **manipulation**;

 }

这样也可以取消掉300ms的延迟,Chrome和Safari都可以生效。

3) 证明一下?

答: 哦。

!function(){
    const html = document.documentElement;
    let touchstartBeginTime = 0;
    const log = (event) =>{
        if(event.type === "touchstart") touchstartBeginTime = Date.now();
        console.log(event.type, Date.now() - touchstartBeginTime);
    }

    html.onclick = log;
    html.ontouchstart = log;
    html.ontouchend = log;
    html.ontouchmove = log;
    html.onmouseover = log;
    html.onmousedown = log;
    html.onmouseup = log;
}();

meta包含 width=device-width or initial-scale=1.0

单击事件触发顺序:


1.png

双击事件触发顺序:


2.png

meta不包含 width=device-width or initial-scale=1.0

单击事件触发顺序:


3.png

双击事件触发顺序:


4.png

4)Tap事件是啥?

答: 在zepto和fastclick中所用的事件, 原生没有tap事件。

可以按照 zapto 和fastclick 中的实现方式实现tap事件(实现方式不同), 基本比click 快20ms 左右,可能由于在click 之前还需触发mouse事件吧。

参考: 移动端300ms点击延迟和点击穿透
从移动端click到摇一摇

相关文章

  • 你知道的移动端事件可能过时了。。。

    一直以为移动端点击事件会有300ms的延迟,原来只是我觉得,不应该要我觉得[捂脸] 1) 为啥移动端会有click...

  • 移动端事件

    移动端事件 触屏事件 移动端事件要比PC端要简单的多,移动端主要就有ontouchstart ontouchend...

  • 深入理解Flutter的Listener组件

    引言 有过移动端开发经验的同学都知道,移动端的触摸事件是由手指按下、手指移动、手指抬起这些基本事件组成的。 在Fl...

  • 移动端js事件以及相关库

    移动端js事件 移动端的操作方式和PC端是不同的,移动端主要用手指操作,所以有特殊的touch事件,touch事件...

  • 移动端js事件09-21

    移动端js事件 移动端的操作方式和PC端是不同的,移动端主要用手指操作,所以有特殊的touch事件,touch事件...

  • 前端知识移动端js事件 zeptojs swiper boots

    移动端js事件 移动端的操作方式和PC端是不同的,移动端主要用手指操作,所以有特殊的touch事件,touch事件...

  • 移动端库和框架1

    移动端js事件 移动端的操作方式和PC端是不同的,移动端主要用手指操作,所以有特殊的touch事件,touch事件...

  • 移动端JS事件,zeptojs,swiper,bootstrap

    移动端js事件 移动端的操作方式和PC端是不同的,移动端主要用手指操作,所以有特殊的touch事件,touch事件...

  • bootstrap

    移动端js事件 移动端的操作方式和PC端是不同的,移动端主要用手指操作,所以有特殊的touch事件,touch事件...

  • 移动端js事件以及相关库

    移动端js事件 移动端的操作方式和PC端是不同的,移动端主要用手指操作,所以有特殊的touch事件,touch事件...

网友评论

      本文标题:你知道的移动端事件可能过时了。。。

      本文链接:https://www.haomeiwen.com/subject/vqbmuctx.html