加入收藏 | 设为首页 | 会员中心 | 我要投稿 济源站长网 (https://www.0391zz.cn/)- 数据工具、数据仓库、行业智能、CDN、运营!
当前位置: 首页 > 综合聚焦 > 编程要点 > 语言 > 正文

JavaScript中事件冒泡机制如何理解?一文带你看懂

发布时间:2022-02-19 13:48:10 所属栏目:语言 来源:互联网
导读:今天给大家分享的是JavaScript中事件冒泡机制的内容,对于新手来说JavaScript事件冒泡机制比较难理解,因此下文有实例及详细的介绍供大家参考,感兴趣的朋友接下来跟随小编一起来了解一下。 什么是冒泡? DOM事件流(event flow )存在三个阶段:事件捕获阶
    今天给大家分享的是JavaScript中事件冒泡机制的内容,对于新手来说JavaScript事件冒泡机制比较难理解,因此下文有实例及详细的介绍供大家参考,感兴趣的朋友接下来跟随小编一起来了解一下。
 
    什么是冒泡?
    DOM事件流(event  flow )存在三个阶段:事件捕获阶段、 处于目标阶段、 事件冒泡阶段。
 
    事件捕获(event  capturing):通俗的理解就是,当鼠标点击或者触发dom事件时,浏览器会从根节点开始由外到内进行事件传播,即点击了子元素,如果父元素通过事件捕获方式注册了对应的事件的话,会先触发父元素绑定的事件。
 
    事件冒泡(dubbed  bubbling):与事件捕获恰恰相反,事件冒泡顺序是由内到外进行事件传播,直到根节点。
 
    dom标准事件流的触发的先后顺序为:先捕获再冒泡,即当触发dom事件时,会先进行事件捕获,捕获到事件源之后通过事件传播进行事件冒泡。不同的浏览器对此有着不同的实现,IE10及以下不支持捕获型事件,所以就少了一个事件捕获阶段,IE11、Chrome 、Firefox、Safari等浏览器则同时存在。
 
    addEventListener()方法
    这个方法设定一个事件监听器,当某一事件发生通过设定的参数执行操作。语法是:
 
addEventListener(event, function, useCapture)
 
    参数 event 是必须的,表示监听的事件,例如 click, touchstart 等,就是之前不加前缀 on 的事件。
 
    参数 function 也是必须的,表示事件触发后调用的函数,可以是外部定义函数,也可以是匿名函数。
 
    参数 useCapture 是选填的,填true或者false,用于描述事件是冒泡还是捕获,true表示捕获,默认的false表示冒泡。
 
    移除事件监听
 
    如果要移除 addEventListener() 添加的事件监听,就要使用removeEventListener(),语法是:
 
removeEventListener(event, function)
 
    参数与addEventListener()一致。
 
    兼容性
 
    IE 8及更早的版本,和Opera 7.0及更早的版本,不支持 addEventListener() 和 removeEventListener() 方法,他们使用的是一下方法代替:
 
    添加事件:
 
attachEvent(event, function)
 
    移除事件:
 
**detachEvent(event, function) **
 
    可以用以下方法解决兼容性问题:
 
if (div1.addEventListener) {
         div1.addEventListener('click', function () {
             console.log("支持")
         });
} else if (div1.attachEvent) {
         div1.attachEvent('onclick', function () {
             console.log("不支持")
         });
}
    冒泡和捕获的具体区别
 
    HTML
 
    <div id="div1">
         <div id="div2"></div>
    </div>
    JS
 
<script>
        var div1 = document.getElementById("div1");
        var div2 = document.getElementById("div2");
        div1.addEventListener('click',function(){
            console.log("div1--捕获阶段")
        },true);
        div2.addEventListener('click',function(){
            console.log("div2--捕获阶段")
        },true);
        div1.addEventListener('click',function(){
            console.log("div1--冒泡阶段")
        });
        div2.addEventListener('click',function(){
            console.log("div2--冒泡阶段")
        });
</script>
    输出结果(点击div2的时候执行的结果)
 
 
 
    解决办法
 
function stopBubble(e) {
         if (e && e.stopPropagation) {
                e.stopPropagation(); //因此它支持W3C的stopPropagation()方法
         } else {
             window.event.cancelBubble = true; //否则,我们需要使用IE的方式来取消事件冒泡
         }
}

(编辑:济源站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    热点阅读