氣泡從水底開始往上升,從深到淺,升到最上面。在上升的過程中,氣泡會經過不同深度的水。相對應地:這個氣泡就相當於我們這裡的事件,而水則相當於我們的整個dom樹;事件從dom 樹的底層,層層往上傳遞,直到傳遞到dom的根節點。當子元素與父元素有相同的事件時,當子元素被觸發時父元素也會被觸發冒泡機制
在不同瀏覽器中,冒泡的程度不同:
IE 6.0:
p -> body -> html -> document
其他瀏覽器:
p -> body -> html -> ; document -> window
並不是所有的事件都能冒泡,以下事件不冒泡:blur、focus、load 、unload
當子元素與父元素有相同的事件時,當子元素被觸發時父元素也會被觸發冒泡機制。冒泡事件,以下程式碼:
<p id="father"> <button id="btn">点击</button></p>
father{ width: 300px; height: 300px; background-color: red; margin: auto; }
# #
window.onload = function () { var father = document.getElementById("father"); var btn = document.getElementById("btn"); btn.onclick = function () { alert("点击了按钮"); }; father.onclick = function () { alert("点击了父标签"); }; document.onclick = function () { alert("点击了文档"); } }
阻止冒泡的方法
標準瀏覽器和ie瀏覽器
w3c:event.stopPropagation() proPagation
IE:event .cancelBubble = true
event.cancelBubble = true; }
window.onload = function () { var father = document.getElementById("father"); var btn = document.getElementById("btn"); btn.onclick = function () { if(event && event.stopPropagation){ // w3c标准 阻止冒泡机制 event.stopPropagation(); }else{ // IE系列 IE 678 event.cancelBubble = true; } alert("点击了按钮"); }; father.onclick = function () { if(event && event.stopPropagation){ // w3c标准 阻止冒泡机制 event.stopPropagation(); }else{ // IE系列 IE 678 event.cancelBubble = true; } alert("点击了父标签"); }; document.onclick = function () { alert("点击了文档"); } }
以上是JavaScript事件擷取與事件冒泡的詳細內容。更多資訊請關注PHP中文網其他相關文章!