事件冒泡和事件捕获机制

二者作用:描述事件触发时序问题


事件捕获:从document到触发事件的那个节点,即自上而下的去触发事件---由外到内
事件冒泡:自下而上的去触发事件---由内到外

阻止事件冒泡

可以通过以下三种方法做到不同程度的阻止。

A:return false --->在事件的处理中,可以阻止默认事件和冒泡事件。

B:event.preventDefault()---> 在事件的处理中,可以阻止默认事件但是允许冒泡事件的发生。

C:event.stopPropagation()---> 在事件的处理中,可以阻止冒泡但是允许默认事件的发生。


绑定事件方法的第三个参数,就是控制事件触发顺序是否为事件捕获
true,事件捕获;false,事件冒泡
一般默认false,即事件冒泡
Jquery的e.stopPropagation会阻止冒泡,意思就是到DOM为止,祖先级的事件就不要触发了

下面是我尝试的例子:

 <!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>事件冒泡与事件捕获</title>
    <script>
        window.onload = function () {
            document.getElementById("parent").addEventListener("click",function(e){
                alert("parent事件被触发,"+this.id);
            },true)
            document.getElementById("child").addEventListener("click",function(e){
                alert("child事件被触发,"+this.id)
            },true)
        }

    </script>
</head>
<body>
<div id="parent">
    parent事件
      <div id="child" class="child">
    child事件
    </div>
</div>
</body>
</html>

例子里我加了第三个true,是事件捕获。

如果不加则是默认的事件冒泡,这时候事件触发时序就是自内向外

猜你喜欢

转载自570109268.iteye.com/blog/2390897