欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

ISO处理jq事件

程序员文章站 2022-07-14 22:52:49
...

jq事件在IOS上,如果标签本身不具备某些功能,而我们通过document或者body绑定上去的话,有些事件是不起作用的,同时在IOS上jq事件也存在延迟。

事件不起作用

这里点击事件为例,在IOS中本身默认不可点击的元素,如(div, span),此时点击事件会失效。

解决办法

  1. 将click事件直接绑定到目标元素。
  2. 将目标元素换成 a 标签或者 button 等可以点击的元素。
  3. click事件委托到非 document 或者 body 的父级元素上。
  4. 给目标元素加一条样式规则 cursor: pointer。

说明:

    1、具体的方法按照自己的遇到的情况而决定。

    2、如果动态增加的元素绑定事件的时候,如果离不开 document 或者 body 的话,为了避免事件,我们只能将操作的标签换成 a 或者 button。

 

事件延迟

移动浏览器为什么会设置300毫秒的等待时间呢?这与双击缩放的方案有关。平时我们有可能已经注意到了,双击缩放,即用手指在屏幕上快速点击两次,可以看到内容或者图片放大,再次双击,浏览器会将网页缩放至原始比例。

浏览器捕获第一次单击后,会先等待一段时间,如果在这段时间区间里用户未进行下一次点击,则浏览器会做单击事件的处理。如果这段时间里用户进行了第二次单击操作,则浏览器会做双击事件处理。这段时间就是上面提到的300毫秒延迟。

解决办法

方法一、进制缩放

<meta name="viewport" content="width=device-width user-scalable= 'no'">  

方法二、fastclick.js

FastClick 是 FT Labs 专门为解决移动端浏览器 300 毫秒点击延迟问题所开发的一个轻量级的库。简而言之,FastClick 在检测到touchend事件的时候,会通过 DOM 自定义事件立即触发一个模拟click事件,并把浏览器在 300 毫秒之后真正触发的click事件阻止掉。使用方法如下。

第一步:在页面中引入fastclick.js文件。

<script src="fastclick.js"></script>

第二步:在js文件中添加以下代码
在 window load 事件之后,在body上调用FastClick.attach()即可

  1 window.addEventListener(function(){
  2     FastClick.attach( document.body );
  3 },false );

如果你项目使用了JQuery,就将上面的代码改写成:

$(function() {    
    FastClick.attach(document.body);    
});  
方法三:指针事件

指针事件最初由微软提出,现已进入 W3C 规范的候选推荐标准阶段 (Candidate Recommendation)。指针事件是一个新的 web 事件系列,相应的规范旨在使用一个单独的事件模型,对所有输入类型,包括鼠标 (mouse)、触摸 (touch)、触控 (stylus) 等,进行统一的处理。
指针事件 (Pointer Events) 目前兼容性不太好,不知道在以后会不会更加支持。

上一篇: float浮动

下一篇: jQuery入门