首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

JavaScript 技巧篇-js增加延迟时间解决单击双击事件冲突,双击事件触发单击事件

js 的单双击事件同时存在会有一个问题:双击事件会同时触发单击事件,两个事件存在冲突。 我们加一个延迟时间就能很好的解决这个问题。...原理: 当接收到第一个点击时,我们先把单击事件存储在这个是全局变量 click_store 里,如果 0.3 秒内没有接收到双击事件,就去执行它,如果接收到了,我们把它清理掉,然后去执行双击事件。...var click_store // 定义一个全局变量存储单击触发事件 document.addEventListener('click', deal_click); document.addEventListener...('dblclick', deal_dblclick); function deal_click(e){ click_store = setTimeout(function(e){ // 单击触发事件...,0.3s延迟 ... },300); } function deal_dblclick(e){ // 单击事件清理 clearTimeout(click_store); // 双击触发事件

6.1K30
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    双击事件与单击事件的那些事

    双击事件与单击事件的那些事 前言 项目遇到了双击事件会同时触发单击事件的bug,还是简单记录一下。 心里话:日更太累了。以前都是单独花好几天的时间去看别人的博客,看很多博客后再慢慢输出。..."); } function mydblclick() { console.error("双击事件"); } 图片 合情合理,双击事件也是两次点击事件,所以同时会触发单击事件click和双击事件...但是需求是单击双击不同的处理,所以双击的时候不应该触发单击事件。 解决方案 思路:可以使用函数防抖的做法,单击事件触发后,开启一个定时器,双击事件触发的话就清除定时器。...function mydblclick() { clearTimeout(timer); console.error("双击事件"); } 图片 可以发现还是有问题,双击事件还是会触发一次单击事件...el-checkbox使用注意点 双击事件和单击事件的问题处理完了,再加上一下下项目的踩坑点。 el-checkbox没有事件对象,平常的事件对象在el-checkbox上是布尔值,表示是否选中。

    3.8K30

    基于PyQT实现区分左键双击单击

    在PyQt中没有直接提供左键双击的判断方法,需要自己实现,其思路主要如下所示: 1、起动一个定时器,判断在指定的时间之内,点击次数超过2次,则视为双击(其主要思路判断两次点击的时间差在预测的条件以内)...2、 起动一个定时器,判断在指定的时间之内,点击次数超过2次,另外再获取鼠标点击的坐标,如果前后两次点击的坐标位置,属于同一个位置,满足这两个条件则判断为双击(其主要思路判断两次点击的时间差在预测的条件以内...self.mouse = "双击" self.isDoubleClick=True def judgeClick(self,e): if self.isDoubleClick...== False: self.mouse="左" else: self.isDoubleClick=False self.mouse = "双击" 或 from...self.timer.isActive() and e.buttons() ==QtCore.Qt.LeftButton: self.timer.stop() self.mouse="双击

    1.8K10

    双击事件(dblclick)时,触发鼠标按下(mousedown) 动作事件

    在一个dom节点的事件绑定中,如果同时绑定了dblclick和mousedown那么想要执行双击事件(dblclick)时能就会触发两次mousedown事件。...在单击的时候(也就是鼠标按下的时候)不会执行双击,但是双击的时候会执行两次单击再执行双击事件。 解决的思路:要想双击执行单击事件,就使用定时器清除掉两个单击事件,留下一个双击事件。...(this.timeOut) console.log(event.target, 'handleDblclick'); }, 关于实现原理 在setTimeout 中的 time=200,大家知道js...要想执行第一次的任务队列,那么定时器时间间隔就必须大于两次单击的时间间隔了。这样才能清除第一次的单击事件,所以,这个200是酌情值,大于间隔就行。...第一次单击任务执行了,是被定时器延时,然后第二次点击的时候给清除了。那么第二次点击事件呢? 在两次单击之后,会立马执行一个双击事件,双击事件的一开头就把这个第二次点击事件给清除了。

    68120

    Android之按钮点击事件(单击双击、长按等)

    在布局文件中添加按钮点击事件 在java文件中添加按钮点击事件 为多个按钮添加点击事件 按钮按下、释放事件 按钮长按事件 按钮长按时过滤掉单击事件 按钮双击事件 按钮双击时过滤掉单击事件 在布局文件中添加按钮点击事件...,因为按钮长按时仍然会触发点击事件。如果只需要处理长按事件的话则不需考虑这一点,如果要在同一个按钮单击或长按时处理不同的内容,则需在长按时过滤掉单击事件。...,因为按钮双击时仍然会先触发单击事件。如果只需要处理双击事件的话则不需考虑这一点,如果要在同一个按钮单击双击时处理不同的内容,则需在双击时过滤掉单击事件。...按钮双击时过滤掉单击事件 双击时过滤单击事件的思路可参考以前在Qt中的应用(QML之MouseArea双击时过滤掉单击事件):在按钮点击时开启定时器,判断300ms内有没有第二次点击,有的话表示双击,...没有的话表示单击

    2.2K20

    彻底解决鼠标单击双击问题的方法(图例)「建议收藏」

    两个月前,己“服役”了几年的鼠标出现了故障,单击经常变成双击,这样想用鼠标移动文件的时候就很麻烦,常常要移动几次才能成功。...如图3,这就是鼠标里面的样子,以前拆友俱乐部也拆开过鼠标,而这次是为了解决单击双击的问题,而这类问题就是出在鼠标的微动开关上,所以我们要继续拆微动开关。...当我们点击鼠标的时候,弹簧上的触点就会和下面的金属触点接触,电脑就会做出相应的反应,也就是单击双击(图5)。...打磨使用的材料是一张比较毛糙的硬纸片,虽然有人会建议用细砂纸打磨,但我建议使用,一是这种材料需要购买,二是细砂纸很容易将触点磨花,这样用不了多久,触点又会被锈蚀。

    3.5K20

    Android 双击退出程序但活动结束功能!

    本片博客将详细介绍: Android 活动中  onKeyDown()   onKeyUp()   onBackPressed()  三个方法的关系及使用 最后给出实现双击退回桌面的源码实例 ----...很明显,要实现这个功能,首先要重写这几个方法,这时我们先注意下文档,我们看到:无论是 onKeyDown onKeyUp 都有类似这么一句话 重点:如果我们仅仅希望使用我们自己的代码,希望再去执行系统代码...,就返回 true ,如果执行完我们自己的代码后,依然打执行系统代码,就返回 false,我们当然希望在执行系统代码,是的活动又被 finish() 调,所以我们这里返回 true。...---- 重写 onKeyUp() 方法 首先判断 是否为 Home 键,如果是,执行自己代码,否则执行系统代码( 不加判断的话,你双击音量键也得退出 ) 代码如下: @Override public...return true; } else { Intent intent = new Intent(Intent.ACTION_MAIN);// 退到后台而结束

    67720
    领券