时间冒泡是指当一个元素触发一个事件时,事件会像水泡一样,从触发元素向它的所有父节点传播,一直到根节点都会接收到此事件
1。如果父元素中注册了相应的事件处理函数,那么尽管事件在子节点触发的,在父元素上注册的事件处理函数同样会被触发1。
时间冒泡示例代码如下:
- 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>