背景浏览器
在开发过程当中,明明调试好的阻止冒泡没有问题,可是真正使用 时候发现阻止冒泡失效了,原来缘由是点击事件里依赖了异步返回结果。异步
正常阻止冒泡写法spa
<div class="aa notice"> <div class="bb notice"></div> </div> <script> var arr = document.getElementsByClassName("notice"); for(let i of arr){ i.addEventListener("click",function (e) { console.log("i",i) // 阻止冒泡 const ev = e || window.event; if (ev && ev.stopPropagation) { //非IE浏览器 ev.stopPropagation(); } else { //IE浏览器(IE11如下) ev.cancelBubble = true; } }) } </script>
阻止冒泡失效的场景:调试
<div class="aa notice"> <div class="bb notice"></div> </div> <script> var arr = document.getElementsByClassName("notice"); for(let i of arr){ i.addEventListener("click",function (e) { console.log("i",i) doReport(reportList, timeout).then(() => { // 阻止冒泡 const ev = e || window.event; if (ev && ev.stopPropagation) { //非IE浏览器 ev.stopPropagation(); } else { //IE浏览器(IE11如下) ev.cancelBubble = true; } }) }) } </script>
doReport是一个上报方法,这里要等待上报完成以后再执行点击逻辑,会致使阻止冒泡失效。code