js jq 單擊和雙擊區(qū)分示例介紹
更新時間:2013年11月05日 15:50:38 作者:
雙擊事件(dblclick)會返回一次單擊事件(click)結(jié)果和一次雙擊事件(dblclick) 結(jié)果,下面有個不錯的示例,大家可以感受下
一:原理:
先看一下點擊事件的執(zhí)行順序:
單擊(click):mousedown,mouseout,click;
雙擊(dblclick):mousedown,mouseout,click , mousedown,mouseout,click,dblclick;
在雙擊事件(dblclick),觸發(fā)的兩次單擊事件(click)中,第一次的單擊事件(click)會被屏蔽掉,但第二次不會。也就是說雙擊事件(dblclick)會返回一次單擊事件(click)結(jié)果和一次雙擊事件(dblclick) 結(jié)果。而不是一次雙擊事件(dblclick)結(jié)果和兩次單擊事件結(jié)果(click)。
如此這般的話,只需消滅掉多余的一次單擊事件(click),這個問題就解決了。
setTimeout
二:代碼:
//定義setTimeout執(zhí)行方法
var TimeFn = null;
$('div').click(function () {
// 取消上次延時未執(zhí)行的方法
clearTimeout(TimeFn);
//執(zhí)行延時
TimeFn = setTimeout(function(){
//do function在此處寫單擊事件要執(zhí)行的代碼
},300);
});
$('div').dblclick(functin () {
// 取消上次延時未執(zhí)行的方法
clearTimeout(TimeFn);
//雙擊事件的執(zhí)行代碼
})
先看一下點擊事件的執(zhí)行順序:
單擊(click):mousedown,mouseout,click;
雙擊(dblclick):mousedown,mouseout,click , mousedown,mouseout,click,dblclick;
在雙擊事件(dblclick),觸發(fā)的兩次單擊事件(click)中,第一次的單擊事件(click)會被屏蔽掉,但第二次不會。也就是說雙擊事件(dblclick)會返回一次單擊事件(click)結(jié)果和一次雙擊事件(dblclick) 結(jié)果。而不是一次雙擊事件(dblclick)結(jié)果和兩次單擊事件結(jié)果(click)。
如此這般的話,只需消滅掉多余的一次單擊事件(click),這個問題就解決了。
setTimeout
二:代碼:
復(fù)制代碼 代碼如下:
//定義setTimeout執(zhí)行方法
var TimeFn = null;
$('div').click(function () {
// 取消上次延時未執(zhí)行的方法
clearTimeout(TimeFn);
//執(zhí)行延時
TimeFn = setTimeout(function(){
//do function在此處寫單擊事件要執(zhí)行的代碼
},300);
});
$('div').dblclick(functin () {
// 取消上次延時未執(zhí)行的方法
clearTimeout(TimeFn);
//雙擊事件的執(zhí)行代碼
})
相關(guān)文章
設(shè)計模式中的組合模式在JavaScript程序構(gòu)建中的使用
組合模式一般是將一系列類似的小對象組合成大的對象,由這個大對象提供接口來對里面的小對象進(jìn)行操作,下買呢我們來詳細(xì)看一下設(shè)計模式中的組合模式在JavaScript程序構(gòu)建中的使用2016-05-05javascript 語法基礎(chǔ) 想學(xué)習(xí)js的朋友可以看看
javascript 語法基礎(chǔ),都是一些大體的說下常見問題,適合有點別的程序基礎(chǔ)的朋友。2009-12-12鍵盤事件中keyCode、which和charCode 的兼容性測試
鍵盤事件中keyCode、which和charCode 的兼容性測試...2007-03-03