javascript的事件冒泡【转】

出处:http://www.cnblogs.com/sanshi/archive/2009/02/18/1393165.html (感谢三生石上)

这是一个基础性的文章,使用Javascript观察DOM中的事件冒泡机制,并介绍如何阻止默认行为和如何组织事件冒泡的方法。

1. 第一个例子可以在Firefox下运行

复制代码
<div id="container1" onclick="alert('click container1');">
    
<div id="container2" onclick="alert('click container2');">
        
<href="http://www.google.com" target="_blank" onclick="fn1(event);">Google</a>
        
<href="http://www.google.com" target="_blank" onclick="fn2(event);">Google</a>
        
<href="http://www.google.com" target="_blank" onclick="fn3(event);">Google</a>
        
<href="http://www.google.com" target="_blank" onclick="fn4(event);">Google</a>
    
</div>
</div>
复制代码
复制代码
function fn1(event) {
    alert(
'click google');
}

function fn2(event) {
    alert(
'click google');
    event.preventDefault();
}

function fn3(event) {
    alert(
'click google');
    event.stopPropagation();
}

function fn4(event) {
    alert(
'click google');
    event.preventDefault();
    event.stopPropagation();
}
复制代码

点击第一个链接,alert_google -> alert_container2 -> alert_container1 -> open_google_page

点击第二个链接,alert_google -> alert_container2 -> alert_container1

点击第三个链接,alert_google -> open_google_page

点击第四个链接,alert_google

可以看到,事件冒泡是从最初引发事件的HTML节点开始,一步步向上引发父节点的相同事件。

在Firefox中,我们可以通过 preventDefault 函数阻止默认的行为(比如这个例子中,点击链接的默认行为是打开链接地址)

通过 stopPropagation 函数阻止事件冒泡。

相同的过程在IE下的实现有点不同,一是事件对象(event)在IE下是作为 window 对象的一个属性,

二是阻止事件的默认行为或阻止事件冒泡的做法也有所不同,请看:

2. 观察IE下的事件冒泡

复制代码
<div id="container1_ie" onclick="alert('click container1');">
    
<div id="container2_ie" onclick="alert('click container2');">
        
<href="http://www.google.com" target="_blank" onclick="fn1_ie();">Google</a> <a
            
href="http://www.google.com" target="_blank" onclick="fn2_ie();">Google</a>
        
<href="http://www.google.com" target="_blank" onclick="fn3_ie();">Google</a> <a
            
href="http://www.google.com" target="_blank" onclick="fn4_ie();">Google</a>
    
</div>
</div>
复制代码
复制代码
function fn1_ie() {
    alert(
'click google');
}

function fn2_ie() {
    alert(
'click google');
    event.returnValue 
= false;
}

function fn3_ie() {
    alert(
'click google');
    event.cancelBubble 
= true;
}

function fn4_ie() {
    alert(
'click google');
    event.returnValue 
= false;
    event.cancelBubble 
= true;
}
复制代码
同样:

点击第一个链接,alert_google -> alert_container2 -> alert_container1 -> open_google_page

点击第二个链接,alert_google -> alert_container2 -> alert_container1

点击第三个链接,alert_google -> open_google_page

点击第四个链接,alert_google

原文地址:https://www.cnblogs.com/yimiao/p/3143595.html