jQuery - 同时添加click和dblclick事件

Posted 知行合一

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了jQuery - 同时添加click和dblclick事件相关的知识,希望对你有一定的参考价值。

特别提示:本人博客部分有参考网络其他博客,但均是本人亲手编写过并验证通过。如发现博客有错误,请及时提出以免误导其他人,谢谢!欢迎转载,但记得标明文章出处:http://www.cnblogs.com/mao2080/

1、问题描述

最近在做H5视频播放器,有这样的需求:点击视频播放界面可以:暂停/播放,双击视频可以:全屏/退出全屏,但是同时绑定click和Dblclick会有冲突,双击的时候每次都会执行两次click,一次Dblclick这明显不符合要求,于是在网上查找解决办法。

2、解决思路

添加事件的代码比较简单,有两种方法:

  • $("abc").bind({"click":fn,"dblclick":fn});
  • $("abc").click(fn).dblclick(fn)

目前的问题是无论双击或者单击都只执行单击的function,为什么呢?
下面我们说一下双击的机制:

双击(dblclick)的流程是:mousedown,mouseout,click,mousedown,mouseout,click,dblclick;

要想实现双击我们必须屏蔽这两次click,因此我们在click里面设置一个定时器,延迟执行function。

3、代码样例

 1 var _time = null;
 2 $(this).find("tr").dblclick(function(e){
 3     clearTimeout(_time);
 4     console.log("dblclick");
 5     //真正双击代码
 6 
 7 }).click(function(e){
 8     clearTimeout(_time);
 9     _time = setTimeout(function(){
10         console.log("click");
11         //单击事件在这里
12 
13     }, 300);
14 });

4、参考网站

以上是关于jQuery - 同时添加click和dblclick事件的主要内容,如果未能解决你的问题,请参考以下文章

如何在 JQuery 中添加的类上执行 .click()?

用jquery,实现让快速双击只调用一次对象的click事件。

jquery表格列里面 click 和hover 冲突

jquery 动态添加的元素 绑定事件click失效

jquery中click事件的累加绑定,点击一次,执行多次

小5聊jQuery使用on绑定未来元素同时off仍然出现被绑定多次click点击事件分析和原因,自己挖坑系列