码迷,mamicode.com
首页 > Web开发 > 详细

js的事件冒泡,事件捕获

时间:2018-09-07 15:57:53      阅读:141      评论:0      收藏:0      [点我收藏+]

标签:事件冒泡   sel   var   selector   UNC   log   listener   htm   query   

 

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

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

技术分享图片

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

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);

技术分享图片

技术分享图片

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

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);

技术分享图片

技术分享图片

 

js的事件冒泡,事件捕获

标签:事件冒泡   sel   var   selector   UNC   log   listener   htm   query   

原文地址:https://www.cnblogs.com/naturl/p/9604695.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!