<br>
事件相容
function myfn(e){ var evt = e ? e:window.event; }
js停止冒泡
function myfn(e){ window.event? window.event.cancelBubble = true : e.stopPropagation(); }
js阻止預設行為
function myfn(e){ window.event? window.event.returnValue = false : e.preventDefault(); }
#w3c的方法是e.stopPropagation(),IE則是使用e.cancelBubble = true
stopPropagation也是事件物件(Event)的一個方法,作用是阻止目標元素的冒泡事件,但是會不阻止預設行為。什麼是冒泡事件?如在一個按鈕是綁定一個”click”事件,那麼”click”事件會依次在它的父級元素中被觸發 。 stopPropagation就是阻止目標元素的事件冒泡到父級元素。如:·
<div id='div' onclick='alert("div");'> <ul onclick='alert("ul");'> <li onclick='alert("li");'>test</li> </ul> </div>
上面的,Demo如下,我們點擊test時,會依序觸發alert(“li”),alert(“ul”),alert(“div”),這就是事件冒泡。
#阻止冒泡
window.event? window.event.cancelBubble = true : e.stopPropagation();
w3c的方法是e.preventDefault() ,IE則是使用e.returnValue = false;
preventDefault它是事件物件(Event)的一個方法,作用是取消一個目標元素的預設行為。既然是說預設行為,當然是元素必須有預設行為才能被取消,如果元素本身就沒有預設行為,呼叫當然就無效了。什麼元素有預設行為呢?如連結,提交按鈕等。當Event 物件的 cancelable為false時,表示沒有預設行為,這時即使有預設行為,呼叫preventDefault也是不會運作的。
我們都知道,連結的預設動作就是跳到指定頁面,下面就以它為例,阻止它的跳躍:
//假定有链接<a href="http://caibaojian.com/" id="testA" >caibaojian.com</a> var a = document.getElementById("testA"); a.onclick =function(e){ if(e.preventDefault){ e.preventDefault(); }else{ window.event.returnValue == false; } }
javascript的return false只會阻止預設行為,而是用jQuery的話則既阻止預設行為又防止物件冒泡。
下面這個使用原生js,只會阻止預設行為,不會停止冒泡
<div id='div' onclick='alert("div");'> <ul onclick='alert("ul");'> <li id='ul-a' onclick='alert("li");'><a href="http://caibaojian.com/"id="testB">caibaojian.com</a></li> </ul> </div> var a = document.getElementById("testB"); a.onclick = function(){ return false; };
## 下面這個是使用
jQuery,既阻止預設行為又停止冒泡
//code from <div id='div' onclick='alert("div");'> <ul onclick='alert("ul");'> <li id='ul-a' onclick='alert("li");'><a href="http://caibaojian.com/"id="testC">caibaojian.com</a></li> </ul> </div> $("#testC").on('click',function(){ return false; });
總結使用方法
function stopBubble(e) { //如果提供了事件对象,则这是一个非IE浏览器 if ( e && e.stopPropagation ) //因此它支持W3C的stopPropagation()方法 e.stopPropagation(); else //否则,我们需要使用IE的方式来取消事件冒泡 window.event.cancelBubble = true; }
當需要阻止預設行為時,可以使用
//阻止浏览器的默认行为 function stopDefault( e ) { //阻止默认浏览器动作(W3C) if ( e && e.preventDefault ) e.preventDefault(); //IE中阻止函数器默认动作的方式 else window.event.returnValue = false; return false; }
事件注意點
function a(e){ var e = (e) ? e : ((window.event) ? window.event : null); var e = e || window.event; // firefox下window.event为null, IE下event为null }
<br/>
以上是js怎麼停止冒泡和阻止瀏覽器預設行為實例的詳細內容。更多資訊請關注PHP中文網其他相關文章!