什么是时间冒泡?

时间冒泡是指当一个元素触发一个事件时,事件会像水泡一样,从触发元素向它的所有父节点传播,一直到根节点都会接收到此事件

1。如果父元素中注册了相应的事件处理函数,那么尽管事件在子节点触发的,在父元素上注册的事件处理函数同样会被触发1。

时间冒泡示例代码如下:

html 复制代码
<!DOCTYPE html>
<html>
<body>

<p id="demo">点击我,父元素会显示点击事件!</p>

<button id="myBtn">点击我</button>

<script>
document.getElementById("myBtn").addEventListener("click", function(event) {
  var eventType = event.type; //获取事件类型
  var target = event.target; //获取事件目标
  var parent = target.parentNode; //获取父元素
  while(parent !== null) { //循环遍历父元素
    if(parent.tagName === "P") { //如果父元素是p标签
      parent.textContent += "\n" + eventType + " 事件在 " + target.tagName + " 上被触发"; 
    }
    parent = parent.parentNode; //继续向上遍历
  }
});
</script>

</body>
</html>
相关推荐
Zyx200712 分钟前
JavaScript 中的 this:作用域陷阱与绑定策略
javascript
唐叔在学习13 分钟前
前端响应式设计实践:布局与字体自适应方案
前端·响应式设计
海云前端117 分钟前
如果要设计一个开源的Code EditorSDK,你会向开发者暴露哪些API?
前端
2501_9462447820 分钟前
Flutter & OpenHarmony OA系统底部导航栏组件开发指南
android·javascript·flutter
Access开发易登软件28 分钟前
Access 数据可视化:如何制作箱形图
前端·数据库·vba·access·access开发
Tiramisu202334 分钟前
【VUE】删除 node_modules几种高效方法
前端·javascript·vue.js
钰fly34 分钟前
Windows Forms开发工具与功能总结表
前端·c#
共享家952737 分钟前
测试常用函数(一)
java·前端·javascript
两个人的幸福online38 分钟前
给cocos 3.8 消息控制器
开发语言·javascript·ecmascript
林恒smileZAZ41 分钟前
vue对接海康摄像头-H5player
前端·javascript·vue.js