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

問(wèn)題效果展示:

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

解決問(wèn)題效果展示:

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

我這里兩個(gè)單擊事件觸發(fā)的時(shí)間間隔設(shè)置在等于300毫秒,這里需要根據(jù)實(shí)際情況而定。
源碼如下:
<!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)過(guò)元素的事件
$("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() { //在單擊事件中添加一個(gè)setTimeout()函數(shù),設(shè)置單擊事件觸發(fā)的時(shí)間間隔
$("body").append("<p>click事件</p>");
}, 300);
})
$("div").bind("dblclick.a", function() { //雙擊事件
clearTimeout(timer); //在雙擊事件中,先清除前面click事件的時(shí)間處理
$("body").append("<p>dblclick事件</p>");
})
$("div").bind("mouseover.a", function() { //鼠標(biāo)經(jīng)過(guò)元素的事件
$("body").append("<p>mouseover事件</p>");
})
$("div").bind("mouseout.a", function() { //鼠標(biāo)移出元素的事件
$("body").append("<p>mouseout事件</p>");
})
})
</script>
</html>
以上就是jquery單擊和雙擊事件沖突解決方案,希望對(duì)大家的學(xué)習(xí)有所幫助。
相關(guān)文章
jQuery+PHP+MySQL實(shí)現(xiàn)無(wú)限級(jí)聯(lián)下拉框效果
這篇文章主要介紹了jQuery+PHP+MySQL實(shí)現(xiàn)無(wú)限級(jí)聯(lián)效果的相關(guān)資料,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-02-02
jquery 正整數(shù)數(shù)字校驗(yàn)正則表達(dá)式
本文主要介紹了jquery正整數(shù)數(shù)字校驗(yàn)正則表達(dá)式的方法。具有一定的參考價(jià)值,下面跟著小編一起來(lái)看下吧2017-01-01
jQuery圖片特效插件Revealing實(shí)現(xiàn)拉伸放大
本文給大家分享的是jQuery圖片展示效果,使用的是jQuery Revealing插件,不點(diǎn)擊的情況下,圖片整齊排列成一行,當(dāng)任意一個(gè)圖片縮略圖被點(diǎn)擊的時(shí)候,該圖片就放大顯示,當(dāng)點(diǎn)擊關(guān)閉按鈕時(shí)圖片又重新還原了縮略圖模式。2015-04-04
jquery mobile實(shí)現(xiàn)撥打電話功能的幾種方法
在做一個(gè)便民服務(wù)電話,用到移動(dòng)web中列出的電話,點(diǎn)擊需要實(shí)現(xiàn)調(diào)用通訊錄,撥打電話功能,有需要的朋友可以參考一下2013-08-08
jQuery擴(kuò)展實(shí)現(xiàn)text提示還能輸入多少字節(jié)的方法
這篇文章主要介紹了jQuery擴(kuò)展實(shí)現(xiàn)text提示還能輸入多少字節(jié)的方法,涉及jQuery擴(kuò)展及字符串操作相關(guān)技巧,需要的朋友可以參考下2016-11-11

