js的事件冒泡,事件捕获

 

addEventListener() 方法可以指定 "useCapture" 参数来设置传递事件类型:false→冒泡       true→捕获       默认false。

内部元素为p标签,外部元素为div标签,实验效果图如下:

在 冒泡 中,内部元素的事件会先被触发,然后再触发外部元素,顺序:内部==>外部

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
css:
.whb100{width: 100px;height: 100px;border:1px dotted red}
.whb200{width: 200px;height: 200px;border:1px dotted #2ea6df}
.center{margin-left: 25%;margin-top: 25%;}
html:
<div  class="whb200 useCaptureFalse" id="">
      <p  class="whb100 center useCaptureFalse2"></p>
</div>
js:
var useCaptureFalse=document.querySelector(".useCaptureFalse")
var useCaptureFalse2=document.querySelector(".useCaptureFalse2")
useCaptureFalse2.addEventListener("click", function() {
    alert(" 你点击了 p 元素 !");
}, false);
useCaptureFalse.addEventListener("click", function(event) {
    alert("你点击了 div 元素!");
    console.log(event)
}, false);

在 捕获 中,外部元素的事件会先被触发,然后再触发内外部元素,顺序:外部==>内部

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
css:
.whb100{width: 100px;height: 100px;border:1px dotted red}
.whb200{width: 200px;height: 200px;border:1px dotted #2ea6df}
.center{margin-left: 25%;margin-top: 25%;}
html:
<div  class="whb200 useCaptureFalse" id="">
      <p  class="whb100 center useCaptureFalse2"></p>
</div>
js:
var useCaptureFalse=document.querySelector(".useCaptureFalse")
var useCaptureFalse2=document.querySelector(".useCaptureFalse2")
useCaptureFalse2.addEventListener("click", function() {
    alert(" 你点击了 p2 元素 !");
}, false);
useCaptureFalse.addEventListener("click", function(event) {
    alert("你点击了 div2 元素!");
    console.log(event)
}, false);

 

posted @   时光凉忆  阅读(236)  评论(0编辑  收藏  举报
编辑推荐:
· [.NET]调用本地 Deepseek 模型
· 一个费力不讨好的项目,让我损失了近一半的绩效!
· .NET Core 托管堆内存泄露/CPU异常的常见思路
· PostgreSQL 和 SQL Server 在统计信息维护中的关键差异
· C++代码改造为UTF-8编码问题的总结
阅读排行:
· CSnakes vs Python.NET:高效嵌入与灵活互通的跨语言方案对比
· DeepSeek “源神”启动!「GitHub 热点速览」
· 我与微信审核的“相爱相杀”看个人小程序副业
· Plotly.NET 一个为 .NET 打造的强大开源交互式图表库
· 上周热点回顾(2.17-2.23)
点击右上角即可分享
微信分享提示