当前位置:网站首页>绑定点击事件,当点击事件里依赖异步返回结果则阻止冒泡失效

绑定点击事件,当点击事件里依赖异步返回结果则阻止冒泡失效

2020-12-07 16:44:14 蓓蕾心晴

背景

在开发过程中,明明调试好的阻止冒泡没有问题,但是真正使用 时候发现阻止冒泡失效了,原来原因是点击事件里依赖了异步返回结果。

正常阻止冒泡写法

<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是一个上报方法,这里要等待上报完成之后再执行点击逻辑,会导致阻止冒泡失效。

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

版权声明
本文为[蓓蕾心晴]所创,转载请带上原文链接,感谢
https://cloud.tencent.com/developer/article/1757523