`
MauerSu
  • 浏览: 514755 次
  • 性别: Icon_minigender_1
  • 来自: 北京
文章分类
社区版块
存档分类
最新评论

解决jQuery中dbclick事件触发两次click事件

 
阅读更多

源:http://js8.in/610.html

评:

jQuery事件绑定中,dbclick可以触发两次click事件。例如一个DOM元素div,既绑定了 click 事件,又绑定了 dblclick 事件,这两个事件分别要做独立的事情。事件处理上没有冲突,都可以各自完成各自的操作。双击的时候虽然是执行了 dblclick 事件,但是在这之前,也执行了click 事件,那么,如何来禁止或者说屏蔽这次多余的 click 事件呢?本文将提供给您一个比较好的解决办法。

产生原理分析

  首先,来了解一下点击事件发生的先后顺序:

单击:mousedown, mouseup, click
双击:mousedown, mouseup, click, mousedown, mouseup, click, dblclick
  由此看来,dblclick 事件发生之前,实际上发生了两次 click 事件。其中,第一次的 click 是会被屏蔽掉,但是第二次则不会,所以就出现在双击的时候,也触发 click 事件。

解决办法

  知道了原因,接下来自然就是想办法把这次 click 给屏蔽掉,但是由于各浏览器均未提供直接去停止事件的方法,所以值得改变思路。
  由于我们只需要屏蔽一次 click 事件即可,由此联想到,可以利用 setTimeout() 方法来延时完成 click 事件的处理,在需要停止 click 的时候利用 clearTimeout() 方法停止这一事件的处理。这样,就可以比较容易的写出如下的 javascript 代码:

var timer = null; function do_click(event) {
 clearTimeout(timer); // 这里加一句是为了兼容 Gecko 的浏览器 /
if (event.detail == 2) 
return ; 
// 同上句的作用 
timer = setTimeout(function() { 
// click 事件的处理 
}, 300); } 
function do_dblclick(event) { 
clearTimeout(timer);
 // dblclick 事件的处理 
}

问题总结

  从测试结果来看,如果前后两次点击的时间在 300ms 左右的时候,还是很容易出现 click 和 dblclick 事件被“同时”调用的情况,而如果间隔的时间更短或更长,则只会有 click 或 dblclick 事件。
  所以,应该说这个方法已经在很大程度上,避免了 click 和 dblclick 事件的“同时”存在问题。当然,它还没有达到完全解决的程度。

注意

windows 的控制面板里是可以调鼠标的双击速度的(Linux 等系统下能不能调,俺就不清楚了),这点对于程序还是有一定影响,大家可以自己调节下试试看~
经过测试,延时 300ms 是一个比较理想的事件,既考虑到对鼠标操作并不十分顺利的朋友,也兼顾 click 事件的响应速度
以上代码,只在 IE6、FF3、Chrome 中测试过,并未出现问题

w3c标准是没有dblclick的,而是通过event.detail来判断是单击或双击

分享到:
评论

相关推荐

    jQuery事件之鼠标事件

    ### jQuery中的鼠标事件详解 #### 一、引言 在前端开发中,处理用户的交互行为是必不可少的一部分。jQuery作为一款流行的JavaScript库,极大地简化了这些交互的处理方式。本文将重点介绍jQuery中与鼠标相关的事件...

    jQuery事件及绑定.pptx

    JavaScript+jQuery 网页特效设计 ...当文本框(包括和中的文本被选中的时触发) scroll() 当滚动条发生变化时触发 resize() 当调整浏览器窗口大小时触发 2、事件的绑定 bind() 方法:可以向被选元素添加一个或多

    jQuery鼠标事件总结

    (2):dbclick事件:dbclick事件在用户完成迅速连续的两次点击之后触发,双击的速度取决于操作系统的设置。一般双击事件在页面中不经常使用。 $('p').dbclick(function(){ alert('dbclick function

    jQuery-1.9.1源码分析系列(十)事件系统之事件体系结构

    DeanEdwards的AddEvent()方法的核心是维护一个事件处理器列表,每个事件类型(如click, dbclick, change等)对应一个处理器数组。通过这种方式,DeanEdwards的设计可以为同一个事件类型附加多个处理函数。此外,为了...

    jQuery中change事件用法实例

    对于单击、双击等其他类型的事件,可能需要使用不同的jQuery事件处理器,比如click()、dbclick()等。 此外,在使用jQuery绑定事件时,有时也会遇到事件冒泡的问题,即事件从触发元素向上逐级传递到根元素。在大多数...

    jQuery鼠标事件汇总

    鼠标事件是在用户移动鼠标光标或者使用任意鼠标键点击...2、dbclick事件:迅速连续的两次点击时触发  $(‘p’).dbclick(function(){}); 示例: $(button).dblclick(function(){ $(p).slideToggle(); }); 3、moused

    jQuery响应鼠标事件并隐藏与显示input默认值

    在本例中,我们主要关注的是focus(当input元素获得焦点时触发)和blur(当input元素失去焦点时触发)这两个事件。 **HTML input元素的属性** HTML的input元素是一个用于搜集用户输入的通用表单元素。它的用途非常...

    关于Jquery中的bind(),on()绑定事件方式总结

    在这篇总结中,我们将深入探讨jQuery中的bind()和on()两种事件绑定方式。 首先,我们要了解bind()方法。bind()方法是jQuery早期版本中用来绑定事件的函数。它在jQuery 1.7版本之后被on()方法所推崇。bind()方法的...

    Jquery教程学习笔记

    17. **事件类型**:`event.type`提供事件的类型,例如`click`, `dbclick`, `mouseover`等。 18. **键盘事件**:`.keydown()`监听键盘按下事件,`event.which`返回对应的ASCII码。 19. **mouseover与mouseenter**:...

    深入理解jQuery事件绑定

    在深入理解jQuery事件绑定的文章中,作者向读者介绍了如何使用jQuery的不同方法来绑定事件,并对它们的适用情况和差异进行了阐述。以下是从文章内容中提取的知识点: 1. jQuery的事件绑定方法主要包括bind()、live...

    jquery实现鼠标滑过小图查看大图的方法

    JQuery支持多种鼠标事件,包括click、dbclick、mouseover、mouseout和mousemove等。在本例中,使用了mouseover、mouseout和mousemove事件来实现鼠标滑过小图查看大图的功能。具体地,当鼠标滑过链接时,显示大图;当...

    Jquery实现的角色左右选择特效

    - 使用JQuery的.dbclick()方法绑定双击事件,实现将选项从一个元素移动到另一个。 - 利用JQuery的选中选择器(:selected)来获取被选中的元素。 以上就是JQuery实现角色左右选择特效所需掌握的技术要点和实现细节。...

    JavaScript简单实现弹出拖拽窗口(一)

    - 鼠标事件的处理中,要区分element.onmousedown和element.click的触发时机; - 使用jQuery时要确保已经正确引入了jQuery库,以便使用jQuery提供的方法。 在实现JavaScript弹出拖拽窗口时,需要特别注意窗口定位...

Global site tag (gtag.js) - Google Analytics