話不多說(shuō)直接放源碼,沒(méi)錯(cuò),就是網(wǎng)上隨便一搜就出來(lái)的這個(gè)!
js代碼:
function cancelBubble(e) {
var evt = e ? e : window.event;
if (evt.stopPropagation) { //W3C
evt.stopPropagation();
}else { //IE
evt.cancelBubble = true;
}
}
為什么很多人試了都說(shuō)沒(méi)用呢?
事實(shí)上很多同學(xué)喜歡使用這種方式綁定事件
HTML:
<div onclick="test(this)"></div>
JS:
function test(oo){
//事件處理
}
其實(shí)無(wú)論是哪種方法,傳值都是很難避免的
這也就是這個(gè)方法的局限性
它在這里調(diào)用時(shí),因?yàn)閠est函數(shù)已經(jīng)傳了值,那么我們的e就進(jìn)不來(lái)
這也就造成了調(diào)用了沒(méi)反應(yīng)的問(wèn)題
調(diào)用方法:
在綁定事件的位置,調(diào)用cancelBubble()即可,像這樣:
HTML:
<div class="test" onclick="test()"></div>
JS:
function test(){
cancelBubble()
//事件處理
}
//或者這樣
$(".test").click(function(){
cancelBubble()
//事件處理
})
//或者這樣
$(".test")[0].addEventListener("click",function(){
cancelBubble()
//這樣寫(xiě)似乎可以解決傳值的e的問(wèn)題,因?yàn)閍dd原生方法是異步添加,可相應(yīng)多個(gè)click事件
// 但是如果頁(yè)面是動(dòng)態(tài)添加的元素,需要重復(fù)綁定事件的問(wèn)題仍然頭疼
})
若需要兼容火狐,在調(diào)用該函數(shù)時(shí),如果是在一個(gè)函數(shù)內(nèi)部調(diào)用該函數(shù),那么外部的函數(shù)不可傳值進(jìn)來(lái)
也就是說(shuō),盡量單獨(dú)調(diào)用
emmmm最近才發(fā)現(xiàn)一件事情
事實(shí)上jq的on函數(shù)可以重復(fù)綁定相同事件
也就是說(shuō)
$(oo).on('click',function(){
console.log(1)
})
$(oo).on('click',function(){
console.log(2)
})
在控制臺(tái)打印時(shí),會(huì)輸出1和2 ,而不是只輸出2