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-02jquery 正整數(shù)數(shù)字校驗(yàn)正則表達(dá)式
本文主要介紹了jquery正整數(shù)數(shù)字校驗(yàn)正則表達(dá)式的方法。具有一定的參考價(jià)值,下面跟著小編一起來(lái)看下吧2017-01-01jQuery圖片特效插件Revealing實(shí)現(xiàn)拉伸放大
本文給大家分享的是jQuery圖片展示效果,使用的是jQuery Revealing插件,不點(diǎn)擊的情況下,圖片整齊排列成一行,當(dāng)任意一個(gè)圖片縮略圖被點(diǎn)擊的時(shí)候,該圖片就放大顯示,當(dāng)點(diǎn)擊關(guān)閉按鈕時(shí)圖片又重新還原了縮略圖模式。2015-04-04jquery mobile實(shí)現(xiàn)撥打電話功能的幾種方法
在做一個(gè)便民服務(wù)電話,用到移動(dòng)web中列出的電話,點(diǎn)擊需要實(shí)現(xiàn)調(diào)用通訊錄,撥打電話功能,有需要的朋友可以參考一下2013-08-08jQuery擴(kuò)展實(shí)現(xiàn)text提示還能輸入多少字節(jié)的方法
這篇文章主要介紹了jQuery擴(kuò)展實(shí)現(xiàn)text提示還能輸入多少字節(jié)的方法,涉及jQuery擴(kuò)展及字符串操作相關(guān)技巧,需要的朋友可以參考下2016-11-11