javascript當(dāng)onmousedown、onmouseup、onclick同時(shí)應(yīng)用于同一個(gè)標(biāo)簽節(jié)點(diǎn)Element
更新時(shí)間:2010年01月05日 17:18:58 作者:
先通過(guò)一個(gè)簡(jiǎn)單例子測(cè)試并發(fā)現(xiàn)我說(shuō)的問(wèn)題,讓你有個(gè)直觀的印象,再接著看我的解決辦法。
因?yàn)樵贘avaScript中,mousedown、mouseup、click執(zhí)行順序是從左到右的,更重要的是一旦mousedown事件激活,正常情況(不在mousedown事件中綁定的方法使用alert類似方法,因?yàn)閺棾鰧?duì)象框就阻止了事件傳遞,即后續(xù)調(diào)用事件丟失)下后面兩個(gè)事件也肯定會(huì)被激活。平時(shí)我們?cè)谝粋€(gè)標(biāo)簽上只綁定一個(gè)click事件,其實(shí)觸發(fā)click事件也都調(diào)用了mousedown、mouseup等事件,只是它們調(diào)用周期極短,而且我們又沒(méi)有編寫相關(guān)函數(shù)與這兩個(gè)事件綁定,所以不會(huì)覺(jué)察到?,F(xiàn)在假設(shè)你要在一個(gè)標(biāo)簽上同時(shí)注冊(cè)這幾個(gè)事件,并具綁定指定的處理函數(shù),在實(shí)際開(kāi)發(fā)中,你將會(huì)遇到我下面提及的問(wèn)題。
先通過(guò)一個(gè)簡(jiǎn)單例子測(cè)試并發(fā)現(xiàn)我說(shuō)的問(wèn)題,讓你有個(gè)直觀的印象,再接著看我的解決辦法。
<div id="div1" onmousedown="mouseDownFun();" onmouseup="mouseUpFun();" onclick="clickFun();" style="background:#CCC; border:3px solid #999; width:200px; height:200px; padding:10px"></div>
<input style="margin-top:10px" type="button" onclick="document.getElementById('div1').innerHTML='';" value="清除信息" />
<script type="text/javascript">
function mouseDownFun()
{
document.getElementById('div1').innerHTML += 'mouseDown<br/>';
}
function mouseUpFun()
{
document.getElementById('div1').innerHTML += 'mouseUp<br/>';
}
function clickFun()
{
document.getElementById('div1').innerHTML += 'click<br/>';
}
</script>
現(xiàn)在假設(shè)有這樣一個(gè)需求:在一張圖片上按下mousedown開(kāi)始拖動(dòng)這張圖片,而在這張圖片上發(fā)生mouseup鼠標(biāo)釋放就顯示這張圖片的相關(guān)信息。正常情況下要想mouseup綁定的函數(shù)執(zhí)行,那么mousedown綁定的函數(shù)也執(zhí)行了,而且還是先執(zhí)行的,也就是說(shuō)在你查看圖片信息的時(shí)候,圖片也在拖動(dòng)中。其實(shí)你正真希望的可能是每次執(zhí)行其中一個(gè)方法就好了,比如當(dāng)你按下鼠標(biāo)并很快就釋放掉時(shí),其實(shí)你是想看圖片信息,而不是想拖動(dòng)圖片;相反,如果你按下鼠標(biāo)并停頓了一下,表明你是想準(zhǔn)備拖動(dòng)圖片,這時(shí)候查看信息方法不要執(zhí)行。這怎么做到的呢,根據(jù)上面的分析,我發(fā)現(xiàn)可以用setTimeout函數(shù)來(lái)加以處理實(shí)現(xiàn)這樣的需求(當(dāng)然,如果你有發(fā)現(xiàn)更好的解決辦法,一定要記得與我分享,哈)。下面給出完整例子,很簡(jiǎn)單,也加了注釋,不另外解釋了:
<div id="div1" onmousedown="mouseDownFun();" onmouseup="mouseUpFun();" style="background:#CCC; border:3px solid #999; width:200px; height:200px; padding:10px"></div>
<input style="margin-top:10px" type="button" onclick="document.getElementById('div1').innerHTML='';" value="清除信息" />
<script type="text/javascript">
var doMouseDownTimmer = null;
var isMouseDownDoing = false;
function mouseDownFun()
{
//因?yàn)閙ouseDownFun每次都會(huì)調(diào)用的,在這里重新初始化這個(gè)變量
isMouseDownDoing = false;
//延遲200毫秒才調(diào)用onmousedown真正的處理代碼,如果在200毫秒內(nèi)就釋放鼠標(biāo),把 doMouseDownTimmer清除,那么onmousedown即使調(diào)用了,其實(shí)是沒(méi)有調(diào)用到doMouseDown函數(shù)作為 onmousedown真正要處理的代碼
doMouseDownTimmer = setTimeout(doMouseDown,200);
}
function doMouseDown()
{
//如果200毫秒后調(diào)用了這個(gè)方法,把isMouseDownDoing設(shè)置成true,表明發(fā)生了mouseDown實(shí)際處理,此后mouseUp就不要處理了
isMouseDownDoing = true;
document.getElementById('div1').innerHTML += 'mouseDown<br/>';
}
function mouseUpFun()
{
if (!isMouseDownDoing)
{
clearTimeout(doMouseDownTimmer); //能進(jìn)到這里來(lái),不管三七二十一先把doMouseDownTimmer清除,不然200毫秒后doMouseDown方法還是會(huì)被調(diào)用的
document.getElementById('div1').innerHTML += 'mouseUp<br/>';
}
}
</script>
相關(guān)話題:因?yàn)槠綍r(shí)經(jīng)常用的click事件都跑在mousedown、mouseup之后,我們可以用mouseup代替click(上面的例子就是這樣用的),此時(shí)Element上就不要再注冊(cè)click事件。當(dāng)然,可以的話,還可以直接拿mousedown代替click,事件響應(yīng)將更快,其中在Google的一些產(chǎn)品中有看到這樣的寫法,比如Gmail。
先通過(guò)一個(gè)簡(jiǎn)單例子測(cè)試并發(fā)現(xiàn)我說(shuō)的問(wèn)題,讓你有個(gè)直觀的印象,再接著看我的解決辦法。
復(fù)制代碼 代碼如下:
<div id="div1" onmousedown="mouseDownFun();" onmouseup="mouseUpFun();" onclick="clickFun();" style="background:#CCC; border:3px solid #999; width:200px; height:200px; padding:10px"></div>
<input style="margin-top:10px" type="button" onclick="document.getElementById('div1').innerHTML='';" value="清除信息" />
<script type="text/javascript">
function mouseDownFun()
{
document.getElementById('div1').innerHTML += 'mouseDown<br/>';
}
function mouseUpFun()
{
document.getElementById('div1').innerHTML += 'mouseUp<br/>';
}
function clickFun()
{
document.getElementById('div1').innerHTML += 'click<br/>';
}
</script>
現(xiàn)在假設(shè)有這樣一個(gè)需求:在一張圖片上按下mousedown開(kāi)始拖動(dòng)這張圖片,而在這張圖片上發(fā)生mouseup鼠標(biāo)釋放就顯示這張圖片的相關(guān)信息。正常情況下要想mouseup綁定的函數(shù)執(zhí)行,那么mousedown綁定的函數(shù)也執(zhí)行了,而且還是先執(zhí)行的,也就是說(shuō)在你查看圖片信息的時(shí)候,圖片也在拖動(dòng)中。其實(shí)你正真希望的可能是每次執(zhí)行其中一個(gè)方法就好了,比如當(dāng)你按下鼠標(biāo)并很快就釋放掉時(shí),其實(shí)你是想看圖片信息,而不是想拖動(dòng)圖片;相反,如果你按下鼠標(biāo)并停頓了一下,表明你是想準(zhǔn)備拖動(dòng)圖片,這時(shí)候查看信息方法不要執(zhí)行。這怎么做到的呢,根據(jù)上面的分析,我發(fā)現(xiàn)可以用setTimeout函數(shù)來(lái)加以處理實(shí)現(xiàn)這樣的需求(當(dāng)然,如果你有發(fā)現(xiàn)更好的解決辦法,一定要記得與我分享,哈)。下面給出完整例子,很簡(jiǎn)單,也加了注釋,不另外解釋了:
復(fù)制代碼 代碼如下:
<div id="div1" onmousedown="mouseDownFun();" onmouseup="mouseUpFun();" style="background:#CCC; border:3px solid #999; width:200px; height:200px; padding:10px"></div>
<input style="margin-top:10px" type="button" onclick="document.getElementById('div1').innerHTML='';" value="清除信息" />
<script type="text/javascript">
var doMouseDownTimmer = null;
var isMouseDownDoing = false;
function mouseDownFun()
{
//因?yàn)閙ouseDownFun每次都會(huì)調(diào)用的,在這里重新初始化這個(gè)變量
isMouseDownDoing = false;
//延遲200毫秒才調(diào)用onmousedown真正的處理代碼,如果在200毫秒內(nèi)就釋放鼠標(biāo),把 doMouseDownTimmer清除,那么onmousedown即使調(diào)用了,其實(shí)是沒(méi)有調(diào)用到doMouseDown函數(shù)作為 onmousedown真正要處理的代碼
doMouseDownTimmer = setTimeout(doMouseDown,200);
}
function doMouseDown()
{
//如果200毫秒后調(diào)用了這個(gè)方法,把isMouseDownDoing設(shè)置成true,表明發(fā)生了mouseDown實(shí)際處理,此后mouseUp就不要處理了
isMouseDownDoing = true;
document.getElementById('div1').innerHTML += 'mouseDown<br/>';
}
function mouseUpFun()
{
if (!isMouseDownDoing)
{
clearTimeout(doMouseDownTimmer); //能進(jìn)到這里來(lái),不管三七二十一先把doMouseDownTimmer清除,不然200毫秒后doMouseDown方法還是會(huì)被調(diào)用的
document.getElementById('div1').innerHTML += 'mouseUp<br/>';
}
}
</script>
相關(guān)話題:因?yàn)槠綍r(shí)經(jīng)常用的click事件都跑在mousedown、mouseup之后,我們可以用mouseup代替click(上面的例子就是這樣用的),此時(shí)Element上就不要再注冊(cè)click事件。當(dāng)然,可以的話,還可以直接拿mousedown代替click,事件響應(yīng)將更快,其中在Google的一些產(chǎn)品中有看到這樣的寫法,比如Gmail。
相關(guān)文章
使用Chrome調(diào)試JavaScript的斷點(diǎn)設(shè)置和調(diào)試技巧
這篇文章主要介紹了使用Chrome調(diào)試JavaScript的斷點(diǎn)設(shè)置和調(diào)試技巧,需要的朋友可以參考下2014-12-12使用js獲取url中的參數(shù)并返回一個(gè)對(duì)象方式
這篇文章主要介紹了使用js獲取url中的參數(shù)并返回一個(gè)對(duì)象方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-01-01Map與WeakMap類型在JavaScript中的使用詳解
這篇文章主要介紹了Map與WeakMap類型在JavaScript中的使用,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-11-11JavaScript實(shí)現(xiàn)的貝塞爾曲線算法簡(jiǎn)單示例
這篇文章主要介紹了JavaScript實(shí)現(xiàn)的貝塞爾曲線算法,結(jié)合簡(jiǎn)單實(shí)例形式分析了基于javascript的貝塞爾曲線算法的相關(guān)實(shí)現(xiàn)技巧,需要的朋友可以參考下2018-01-01基于bootstrap實(shí)現(xiàn)廣告輪播帶圖片和文字效果
這篇文章主要介紹了基于bootstrap實(shí)現(xiàn)廣告輪播帶圖片和文字效果,效果非常棒,需要的朋友可以參考下2016-07-07基于javascript的JSON格式頁(yè)面展示美化方法
本文介紹的方法基于javascript,css和myFunction結(jié)合可實(shí)現(xiàn)頁(yè)面展示轉(zhuǎn)換,下面有個(gè)示例,大家可以參考下2014-07-07使用JavaScript實(shí)現(xiàn)ajax的實(shí)例代碼
實(shí)現(xiàn)ajax之前必須要?jiǎng)?chuàng)建一個(gè) XMLHttpRequest 對(duì)象。這是必須的。那么對(duì)使用js實(shí)現(xiàn)ajax的代碼感興趣的朋友可以參考下本文2016-05-05