jquery單擊事件和雙擊事件沖突解決方案
本人需要給bootstrap-treeview的樹節(jié)點添加雙擊事件。而該插件原生方法中不帶雙擊事件功能。該插件的節(jié)點默認(rèn)綁定的單擊事件,由此引起了單擊事件和雙擊事件的沖突。
編寫測試代碼
引起沖突的代碼:

問題效果展示:

每一次觸發(fā)雙擊事件都會引起兩次單擊事件
解決沖突的代碼:

解決問題效果展示:

完美解決單擊事件和雙擊事件沖突問題
這里主要用到兩個HTMLDOMWindow對象中函數(shù),settimeout(),clearTimeout()

我這里兩個單擊事件觸發(fā)的時間間隔設(shè)置在等于300毫秒,這里需要根據(jù)實際情況而定。
源碼如下:
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title></title>
</head>
<body>
<div>事件監(jiān)控</div>
</body>
<script type="text/javascript" src="js/jquery.min.js"></script>
<script type="text/javascript">
/*$(function() {
$("div").bind("click.a", function() { //單擊事件
$("body").append("<p>click事件</p>");
})
$("div").bind("dblclick.a", function() { //雙擊事件
$("body").append("<p>dblclick事件</p>");
})
$("div").bind("mouseover.a", function() { //鼠標(biāo)經(jīng)過元素的事件
$("body").append("<p>mouseover事件</p>");
})
$("div").bind("mouseout.a", function() { //鼠標(biāo)移出元素的事件
$("body").append("<p>mouseout事件</p>");
})
})*/
$(function() {
var timer = null;
$("div").bind("click.a", function() { //單擊事件
clearTimeout(timer);
timer = setTimeout(function() { //在單擊事件中添加一個setTimeout()函數(shù),設(shè)置單擊事件觸發(fā)的時間間隔
$("body").append("<p>click事件</p>");
}, 300);
})
$("div").bind("dblclick.a", function() { //雙擊事件
clearTimeout(timer); //在雙擊事件中,先清除前面click事件的時間處理
$("body").append("<p>dblclick事件</p>");
})
$("div").bind("mouseover.a", function() { //鼠標(biāo)經(jīng)過元素的事件
$("body").append("<p>mouseover事件</p>");
})
$("div").bind("mouseout.a", function() { //鼠標(biāo)移出元素的事件
$("body").append("<p>mouseout事件</p>");
})
})
</script>
</html>
以上就是jquery單擊和雙擊事件沖突解決方案,希望對大家的學(xué)習(xí)有所幫助。
相關(guān)文章
基于jQuery的message插件實現(xiàn)右下角彈出消息框
有時在頁面加載的時候,需要在頁面的右下角彈出一個小的提示框,顯示一些提示信息給用戶,通過使用jQuery的message插件,可以很方便的實現(xiàn)這個效果,在使用之前先介紹一下message插件中的方法的使用。2011-01-01
ajax+jQuery實現(xiàn)級聯(lián)顯示地址的方法
這篇文章主要介紹了ajax+jQuery實現(xiàn)級聯(lián)顯示地址的方法,涉及jQuery操作Ajax實現(xiàn)級聯(lián)顯示的技巧,非常具有實用價值,需要的朋友可以參考下2015-05-05
jQuery基于Ajax實現(xiàn)讀取XML數(shù)據(jù)功能示例
這篇文章主要介紹了jQuery基于Ajax實現(xiàn)讀取XML數(shù)據(jù)功能,結(jié)合實例形式分析了jQuery基于ajax的get方式獲取xml文件數(shù)據(jù)并輸出顯示相關(guān)操作技巧,需要的朋友可以參考下2018-05-05
jquery.gridrotator實現(xiàn)響應(yīng)式圖片展示畫廊效果
本教程將教大家制作一個jQuery響應(yīng)式圖片展示畫廊效果,所有圖片以網(wǎng)格的形式排列,然后定時隨機(jī)翻轉(zhuǎn)其中某些格子用來切換圖片。這種效果可以用來當(dāng)做背景或裝飾放在我們的網(wǎng)站上。2015-06-06

