FastClick用法[通俗易懂]

FastClick用法[通俗易懂]移动设备上的浏览器默认会在用户点击屏幕大约延迟300毫秒后才会触发点击事件,这是为了检查用户是否在做双击。为了能够立即响应用户的点击事件,才有了FastClick。原因:移动端的双击会缩放导致click判断延迟安装fastclick安装fastclick可以使用npm,Component和Bower。另外也提供了Ruby版的gemfastclick-rails以及.NET提供了Nu…

大家好,又见面了,我是你们的朋友全栈君。

移动设备上的浏览器默认会在用户点击屏幕大约延迟300毫秒后才会触发点击事件,这是为了检查用户是否在做双击。为了能够立即响应用户的点击事件,才有了FastClick。

原因: 移动端的双击会缩放导致click判断延迟

安装fastclick

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

在页面直接引入fastclick.js

 

<script type='application/javascript' src='/path/to/fastclick.js'></script>

使用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:

<a class="needsclick">Ignored by FastClick</a>

 

  在vue中使用

    // 安装

    npm install fastclick

-S

    // 引入

    import FastClick from ‘fastclick’

    // 使用

    FastClick.attach(document.body);

    // 引入

   <script type=’application/javascript’ src=’/path/to/fastclick.js’></script>

    // 在jquery中使用

    $(function() {

        FastClick.attach(document.body);

    });

    // 纯js

    if (‘addEventListener’ in document) {

        document.addEventListener(‘DOMContentLoaded’, function() {

            FastClick.attach(document.body);

        }, false);

    }

不需要使用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

1. 禁用缩放

   `<meta name = “viewport” content=”user-scalable=no” > `

    缺点: 网页无法缩放

2. 更改默认视口宽度

    `<meta name=”viewport” content=”width=device-width”>`

    缺点: 需要浏览器的支持

3. css touch-action

    touch-action的默为 auto,将其置为 none 即可移除目标元素的 300 毫秒延迟

    缺点: 新属性,可能存在浏览器兼容问题

4. tap事件

    zepto的tap事件, 利用touchstart和touchend来模拟click事件

    缺点: 点击穿透

5. fastclick

    原理: 在检测到touchend事件的时候,会通过DOM自定义事件立即出发模拟一个click事件,并把浏览器在300ms之后真正的click事件阻止掉

    缺点: 脚本相对较大

 

   

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/150772.html原文链接:https://javaforall.net

(0)
上一篇 2022年6月19日 下午8:16
下一篇 2022年6月19日 下午8:36


相关推荐

  • java静态多态实例,java多态

    java静态多态实例,java多态市面上对于多态往往有两种说法 一种是多态是通过方法的重载和方法的重写来实现多态 另外一种是父类型的引用指向子类型的对象或者接口类型的引用指向实现接口的类的实例 其实两种说法都不全面 首先 要从字面上来理解什么是多态 多态 即 多种状态 以上两种说法都代表了两种状态 java 中多态可以分为静态多态和动态多态 1 静态多态 demo1publicv i j returni

    2026年3月17日
    2
  • pycharm控制台中文乱码问题

    pycharm控制台中文乱码问题pycharm 控制台中文乱码问题一般是因为之前有配置保存到了文件里 C 盘下 pycharm 文件夹下有配置文件 删除文件后重装 pycharm 配置会重置不过最后解决问题的做法是删除配置文件后 重新装了更新一版本的 pycharm 转载于 https www cnblogs com wangcp 2014 p 4844851 html

    2026年3月20日
    3
  • 什么是重绘和回流?

    什么是重绘和回流?重绘 回流 DOM 性能浏览器的性能大部分都是被这两个问题所消耗重绘 DOM 树没有元素增加或删除 只是样式的改变 会导致浏览器对某一元素进行单独的渲染 这个过程就叫做重绘回流 DOM 树中的元素被增加或者删除 导致浏览器需要重新的去渲染整个 DOM 树 回流比重绘更消耗性能 发生回流必定重绘 重绘不一定会导致回流 因为重绘和回流的存在导致真实 DOM 性能不佳 所以 VUE 和 recat 还有 angular 等框架增加了虚拟 DOM 技术 就是为了减少 DOM 的重绘和回流从而减少浏览器性能消耗 这就是虚拟 DOM 的好处

    2026年3月17日
    2
  • linux top load average过高_load指令是什么意思

    linux top load average过高_load指令是什么意思Linux操作系统loadaverage过高,kworker占用较多cpu今天巡检发现,mc1的K8S服务器集群有些异常,负载不太均衡。其中10.2.75.32-34,49的loadaverage值都在40以上,虽然机器的cpu核数都是40或48核不算严重,但也值得重视。登陆机器查看,执行top发现,cpu的使用率接近40%,sys有20-30,user有10-20。也发现有大量…

    2025年12月2日
    8
  • 总结 数据结构:二分查找法15/4/21

    总结 数据结构:二分查找法15/4/21

    2021年9月6日
    93
  • Earfcn与Frequency转换「建议收藏」

    Earfcn与Frequency转换「建议收藏」EARFCN:E-UTRAAbsoluteRadioFrequencyChannelNumber.FDL=FDL_low+0.1(NDL–NOffs-DL)FUL=FUL_low+0.1(NUL–NOffs-UL)

    2022年10月7日
    5

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号