JS - 解决鼠标单击、双击事件冲突问题(原生js实现)
首先,来了解一下点击事件发生的先后顺序:
单击:mousedown, mouseup, click
双击:mousedown, mouseup, click, mousedown, mouseup, click, dblclick
由于鼠标双击时每一次触发双击事件都会引起两次单击事件和一次双击事件,原生的js不提供专门的双击事件。
因为业务原因,双击和单机都绑定了不同的业务,在双击的时候又触发了单机,影响了页面的正常显示
出现问题的代码:
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title></title>
<script type="text/javascript">
/*
* 页面初始化
*/
function onload() {
document.addEventListener('click', onDocumentClick);
document.addEventListener('dblclick', onDocumenDblClick);
} /*
* 鼠标单击事件响应
* event 鼠标事件对象
*/
function onDocumentClick(event) {
console.log("鼠标单击");
} /*
* 鼠标双击事件响应
* event 鼠标事件对象
*/
function onDocumenDblClick(event) {
console.log("鼠标双击");
}
</script>
</head>
<body onload="onload()">
</body>
</html>
解决办法:
setTimerout
所以双击时为了屏蔽单击事件,引入定时器功能,动态的为每次鼠标单击计时,300ms,300ms内鼠标再次点击会出发双击事件而不走单击事件
解决代码:
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title></title>
<script type="text/javascript">
//单击延时触发
var clickTimeId; /*
* 页面初始化
*/
function onload() {
document.addEventListener('click', onDocumentClick);
document.addEventListener('dblclick', onDocumenDblClick);
} /*
* 鼠标单击事件响应
* event 鼠标事件对象
*/
function onDocumentClick(event) {
// 取消上次延时未执行的方法
clearTimeout(clickTimeId);
//执行延时
clickTimeId = setTimeout(function() {
//此处为单击事件要执行的代码
console.log("鼠标单击");
}, 250);
} /*
* 鼠标双击事件响应
* event 鼠标事件对象
*/
function onDocumenDblClick(event) {
// 取消上次延时未执行的方法
clearTimeout(clickTimeId);
console.log("鼠标双击");
}
</script>
</head>
<body onload="onload()">
</body>
</html>
如果还vue 同样的方法,但是注意有可能会有一些版本不支持,1.0版本是可以,2.0的在线的版本有一些不支持native,到官网中在线引入vue(2019年10月15日)
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>测试单击双击</title>
<meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=0">
<meta name="apple-mobile-web-app-capable" content="yes">
<meta name="apple-mobile-web-app-status-bar-style" content="black">
<style>
#box{
background-color:pink
}
</style>
<script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script>
<script>
window.onload=function(){
//var clickTimeId;
new Vue({
el:'#box',
data:{
clickTimeId:"",
},
methods:{
onDocumentClick(event) {
// 取消上次延时未执行的方法
clearTimeout(this.clickTimeId);
//执行延时
this.clickTimeId = setTimeout(function() {
//此处为单击事件要执行的代码
console.log("0");
}, 250);
},
onDocumenDblClick(event) {
// 取消上次延时未执行的方法
clearTimeout(this.clickTimeId);
console.log("1");
}
}
});
};
</script>
</head>
<body>
<button id="box" @click="onDocumentClick" @dblclick="onDocumenDblClick">
点我啊
</button>
</body>
</html>
在实际使用过程中还发现了一个有趣的应用,我们知道没有设置定时器的时候,双击的时候是触发两次click的事件,如果设置 定时的时间低于170ms的时候 双击时会触发一次单击的事件 如果有特殊需要也可以控制好定时器的时间
2020年2月15号
在实际组态项目中的时候,因为特殊情况,还是有时间冲突的问题,添加了定时器就导致了页面的其他业务不能正常使用了,所以最后还是放弃了定时器这种做法
最终的解决办法:
在单击的时候记录下鼠标的xy位置,然后双击的结束的时候记录此时鼠标的xy位置,通过两次的xy位置进行对比,如果两次的xy位置相同,或者在一个允许很小的范围,就证明是双击了,其他就当做是单击处理,这样一来的问题就都解决,这种方法推荐,亲测可试
JS - 解决鼠标单击、双击事件冲突问题(原生js实现)的更多相关文章
- electron 系统托盘 单击 双击事件冲突解决方法
部分代码 // 任务栏点击事件 let timeCount = 0 tray.on('click', function (Event) { setTimeout(() => { if (time ...
- JS Event 鼠标拖拽事件
<!DOCTYPE html><html> <head> <meta charset="UTF-8"> ...
- js(jquery)鼠标移入移出事件时,出现闪烁、隐藏显示隐藏显示不停切换的情况
<script> $(".guanzhu").hover(function(){ $(".weixinTop").show(); },functio ...
- JQuery如何实现双击事件时不触发单击事件,解决鼠标单双击冲突问题
在jQuery的事件绑定中,如果元素同时绑定了单击事件(click)和双击事件(dblclick),那么执行单击事件(click)时,不会触发双击事件(dblclick), 执行双击事件(dblcli ...
- jquery 单击和双击事件冲突解决方案
先看一下点击事件的执行顺序: 单击(click):mousedown,mouseout,click: 双击(dblclick):mousedown,mouseout,click , mousedown ...
- JQuery解决鼠标单双击冲突问题
转自链接:https://www.shuzhiduo.com/A/xl560MKrzr/ 在jQuery的事件绑定中,如果元素同时绑定了单击事件(click)和双击事件(dblclick),那么执行单 ...
- MVC中使用Echart后台加载数据 实现饼图、折线图、全国地图数据,单击双击事件等
@{ Layout = null; } @if (false) { <script src="~/Js/jquery-easyui-1.5/jquery.min.js"> ...
- JS控制鼠标点击事件
鼠标点击事件就是当鼠标点击元素时,就会出现另一个窗口,类似于百度首页中右上角的“登录”这个按钮,当鼠标点击 登录时,就会出现登录窗口.大体的意思就是这样,直接上代码了,简单易懂. <!DOCTY ...
- JS里关于事件的常被考察的知识点:事件流、事件广播、原生JS实现事件代理
1.JS里面的事件流 DOM2级事件模型中规定了事件流的三个阶段:捕获阶段.目标阶段.冒泡阶段,低版本IE(IE8及以下版本)不支持捕获阶段 捕获事件流:Netscape提出的事件流,即事件由页面元素 ...
随机推荐
- Oracle SQL Trace 和 10046 事件
http://blog.csdn.net/tianlesoftware/article/details/5857023 一. SQL_TRACE 当SQL语句出现性能问题时,我们可以用SQL_TRAC ...
- delphi API: SetWindowPos改变窗口的位置与状态
SetWindowPos 函数功能:该函数改变一个子窗口,弹出式窗口式顶层窗口的尺寸,位置和Z序.子窗口,弹出式窗口,及顶层窗口根据它们在屏幕上出现的顺序排序.顶层窗口设置的级别最高,并且被设置为Z序 ...
- 【WP8.1】系统控件的bug及修复方案
最近开发的时候,发现Windows Phone 8.1 Runtime中的两个控件的存在bug的情况,现总结出来,并给出解决方案. 1.Hub控件 Hub控件的顶部默认是可以拖动来切换HubSecti ...
- [ACM_模拟] HDU 1006 Tick and Tick [时钟间隔角度问题]
Problem Description The three hands of the clock are rotating every second and meeting each other ma ...
- jvm lock低性能分析
日志平台client面临着输出日志的问题.为了避免干扰业务系统,我们采用异步输出的方式.这实际上相当于一个多生产者-单消费者的多线程模型.传统的方式是使用同步加锁的方式,但是这种方式不够高效.之前 钟 ...
- 如何将Jenkins multiline string parameter的多行文本优雅的保存为文件
[现象]: 使用multi-line string parameter获取的文本变量,在jenkins shell里面显示为单行文本(空格分割). [问题]:能否转换为多行文本,并存入文件. [解决方 ...
- 【加密算法】AES
一.简介 AES(Advanced Encryption Standard):高级加密标准,是下一代的加密算法标准,速度快,安全级别高. 用AES加密2000年10月,NIST(美国国家标准和技术协会 ...
- datagridview 代码添加列
int column_key = 0; private DataGridViewTextBoxColumn column_add(string name) { DataGridViewTextBoxC ...
- Regular进阶: 跨组件通信
本文由作者郑海波授权网易云社区发布. 背景 在组件化不断深入的大环境下,无论使用哪种 MDV 框架都最终会遇到一个头疼的问题,就是「跨组件通信」. 下图是个简单的例子 这里包含「事件通信」和「数据通信 ...
- Day 14 列表推导式、表达器、内置函数
一. 列表推导式# l1 = []# for i in range(1,11):# l1.append(i)# print(l1)# #输出结果:[1, 2, 3, 4, 5, 6, 7, 8, 9, ...