[jQuery] Zepto的点透问题如何解决?

1、“点透”是什么你可能碰到过在列表页面上创建一个弹出层,弹出层有个关闭的按钮,你点了这个按钮关闭弹出层后后,这个按钮正下方的内容也会执行点击事件(或打开链接)。这个被定义为这是一个“点透”现象。在前面的项目中遇到了如下图的问题:在点击弹出来的选择组件的右上角完成后会让完成后面的input输入框聚焦,弹出输入键盘,也就是点透了2、为什么会出现点透呢?
这个需要从zepto(或者jqm)源码里面看关于tap的实现方法:
View Code可以看出zepto的tap通过兼听绑定在document上的touch事件来完成tap事件的模拟的,及tap事件是冒泡到document上触发的再点击完成时的tap事件(touchstart\touchend)需要冒泡到document上才会触发,而在冒泡到document之前,用户手的接触屏幕(touchstart)和离开屏幕(touchend)是会触发click事件的,因为click事件有延迟触发(这就是为什么移动端不用click而用tap的原因)(大概是300ms,为了实现safari的双击事件的设计),所以在执行完tap事件之后,弹出来的选择组件马上就隐藏了,此时click事件还在延迟的300ms之中,当300ms到来的时候,click到的其实不是完成而是隐藏之后的下方的元素,如果正下方的元素绑定的有click事件此时便会触发,如果没有绑定click事件的话就当没click,但是正下方的是input输入框(或者select选择框或者单选复选框),点击默认聚焦而弹出输入键盘,也就出现了上面的点透现象。3、点透的解决方法:方案一:来得很直接github上有个fastclick可以完美解决https://github.com/ftlabs/fastclick引入fastclick.js,因为fastclick源码不依赖其他库所以你可以在原生的js前直接加上1 window.addEventListener( "load", function() {
2     FastClick.attach( document.body );
3 }, false );或者有zepto或者jqm的js里面加上1 $(function() {
2     FastClick.attach(document.body);
3 });当然require的话就这样:1 var FastClick = require('fastclick');
2 FastClick.attach(document.body, options);方案二:用touchend代替tap事件并阻止掉touchend的默认行为preventDefault()1 $("#cbFinish").on("touchend", function (event) {
2     //很多处理比如隐藏什么的
3     event.preventDefault();
4 });方案三:延迟一定的时间(300ms+)来处理事件1 $("#cbFinish").on("tap", function (event) {
2     setTimeout(function(){
3     //很多处理比如隐藏什么的
4     },320);
5 });    这种方法其实很好,可以和fadeInIn/fadeOut等动画结合使用,可以做出过度效果理论上上面的方法可以完美的解决tap的点透问题,如果真的倔强到不行,用click

个人简介

我是歌谣,欢迎和大家一起交流前后端知识。放弃很容易,
但坚持一定很酷。欢迎大家一起讨论

主目录

与歌谣一起通关前端面试题

[jQuery] Zepto的点透问题如何解决?相关推荐

  1. jQuery/Zepto的Bootstrap轮播图中图片自适应宽高并居中插件

    2019独角兽企业重金招聘Python工程师标准>>> 今天写了一下午带晚上的jQuery/Zepto的Bootstrap轮播图插件,功能是能够根据当前较短的一边实现自适应宽度,并且 ...

  2. 迷你版jQuery——zepto核心源码分析

    前言 zepto号称迷你版jQuery,并且成为移动端dom操作库的首选 事实上zepto很多时候只是借用了jQuery的名气,保持了与其基本一致的API,其内部实现早已面目全非! 艾伦分析了jQue ...

  3. jquery submit()不能提交表单的解决方法

    jquery submit()不能提交表单的解决方法 参考文章: (1)jquery submit()不能提交表单的解决方法 (2)https://www.cnblogs.com/war-hzl/p/ ...

  4. jquery的ajax()函数传值中文乱码解决方法介绍

    jquery的ajax()函数传值中文乱码解决方法介绍 参考文章: (1)jquery的ajax()函数传值中文乱码解决方法介绍 (2)https://www.cnblogs.com/xuxiaosh ...

  5. 5分钟搞定jQuery zepto.js 面向对象插件

    今天分享一下快速使用jQuery zepto.js的技巧,需要的记得收藏 1.jQuery的引入:本地下载jQuery(后面简称jq)的源文件,开发版本使用非min版,线上使用min版,zepto.j ...

  6. jQuery / zepto ajax 全局默认设置

    jQuery / zepto 的 $.ajax 方法需要配置很多选项, 有些是很常用的每个 ajax 请求都要用到的, 可以全局设置, 避免每次都写. 注意: 此处用的 jQuery 版本是 1.8. ...

  7. jquery validation engine ajax验证,jquery.validationEngine 验证 AJAX 不起作用解决方法

    当前位置:我的异常网» Ajax » jquery.validationEngine 验证 AJAX 不起作用解决方 jquery.validationEngine 验证 AJAX 不起作用解决方法 ...

  8. Zepto Click点透情况解决办法

    查看全文 http://www.taodudu.cc/news/show-806744.html 相关文章: Chrome 控制台console的用法 一个全屏页面切换实例 常用数组方法 JS事件代理 ...

  9. 服务器自动post,jquery ajax $.post自动变GET的解决方式(for CI)

    环境:CI 3.x + windows 2008 + phpstudy + jquery 1.7.2 + apache 以往一直用lnmp,这次用windows+apache,遇到了一些问题,记录下来 ...

最新文章

  1. Udacity机器人软件工程师课程笔记(三十五) - SLAM - 基于网格的FastSLAM
  2. SpringBoot内置tomcat启动原理
  3. 盛趣游戏 html5游戏,盛趣游戏谭雁峰:游戏破局的“精细”时代已来
  4. jdk LocalDateTime mybatis 空指针解决办法
  5. 经验分享 | 二本直博浙大?我只是写了篇论文而已
  6. idea-java项目配置
  7. HM 内存池设计(2) HM6.0内存池设计
  8. sci写作sci写作模板_有写作错误吗? bibisco简介
  9. html label 两端对齐,如果实现表单的label文字两端对齐
  10. Java - HashSet源码解析
  11. 如何对shell脚本进行加密且不影响脚本运行
  12. 管理感悟:技术好的人都有点工作狂
  13. 同义词转换不再有效_1秒变电脑,手机吃鸡新体验,北通E1键鼠转换器上手体验!...
  14. 微信小程序拨号功能,调起手机拨号!
  15. Nginx网络压缩 CSS压缩 图片压缩 JSON压缩
  16. 土地日度交易数据2000-2022
  17. 平时你都用什么软件做笔记?
  18. 全球十大汽车轮胎排名韩泰轮胎:冬季轮胎安全须知
  19. Java工程师 Java基础面试题集合类(Day06)
  20. (flutter)黑苹果系统 Xcode iOS flutter 跑通真机模拟器 此oc clover 彼oc swift

热门文章

  1. winform窗体模板_如何验证角模板驱动的窗体
  2. css 跳动的心_如何用纯CSS为您的情人打造一颗跳动的心
  3. django 传递中文_如何在Django中建立消息传递状态
  4. RESTful服务的第三部分:HATEOAS和Richardson成熟度模型
  5. 项目经济规模的估算方法_估算英国退欧的经济影响
  6. tensorflow基本教程
  7. 基于ASP.NET的新闻管理系统(三)代码展示
  8. Tarjan的强联通分量
  9. 用rem来做响应式开发
  10. java界面中显示图片_java中怎样在界面中显示图片?