Rumah > hujung hadapan web > tutorial js > JavaScript冒泡和捕获的知识介绍(附代码)

JavaScript冒泡和捕获的知识介绍(附代码)

不言
Lepaskan: 2019-03-11 16:22:37
ke hadapan
2800 orang telah melayarinya

本篇文章给大家带来的内容是关于JavaScript冒泡和捕获的知识介绍(附代码),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。

JS 冒泡和捕获是怎么回事

冒泡和捕获是指在元素上的事件被触发的时候,js 传递事件的两种方向,或者说过程。

前言:

如,有这么一个页面 和 js 方法

4185889380-5c8612cd12465_articlex.png

Less: 我用 less写的,如果没有 less 环境,可以无视这段。
.level {
  padding: 50px 80px;
}

.level-template(@level: 1, @color: #fff){
  background-color: darken( @color , 5% * @level);
}

#lv1{ .level-template(1)}
#lv2{ .level-template(2)}
#lv3{ .level-template(3)}
#lv4{ .level-template(4)}
Salin selepas log masuk
HTML
<div id="lv1" class="level">
    <div id="lv2" class="level">
        <div id="lv3" class="level">
            <div id="lv4" class="level">

            </div>
        </div>
    </div>
</div>
Salin selepas log masuk
JS
function $(id) {
    return document.getElementById(id);
}

window.onload = () => {
    $('lv1').addEventListener("click",()=>{console.log('lv1')},true);
    $('lv2').addEventListener("click",()=>{console.log('lv2')},true);
    $('lv3').addEventListener("click",()=>{console.log('lv3')},true);
};
// 上面的 () => {} 为 ES6 的匿名方法的定义方式
// 等同于
function () {
    console.log('lv1')
}
Salin selepas log masuk

上面的 js 做的事:
在页面载入的时候,给三个 div添加 click  监听方法,自己被点击的时候会在 console 中输出自己的 id 值。

页面的结构是这样的  lv1 包含 lv2,lv2 又包含 lv3,当点击 lv3 的时候,其实也点击了 lv2 和 lv1,因为 lv3 在 lv2 内部,点击 lv3 的时候,自然也点击了 lv2 和 lv1,也就是说,点击 lv3 的时候,会触发三个 click 事件。
至于这三个事件触发的顺序,就是所谓的 冒泡  和 捕获。

事件触发经过的三个阶段:

  1. 捕获阶段:先由文档的根节点 document 往事件触发对象,从外向内捕获事件对象;
  2. 定位目标:寻找到目标事件位置(事发地),触发事件;
  3. 冒泡阶段:再从目标事件位置往文档的根节点方向回溯,从内向外冒泡事件对象。

1. 捕获阶段

如上面的例子,在 lv3 被点击的时候,js 会从文档的最上层开始,由外向内寻找点击事件的起源,也就是 lv3。那么这个由外向内的过程就是 lv1 --> lv2 --> lv3,这三个 p 的 click 事件按照这个过程依次被触发。
这个触发的方向就是捕获的方向。

2. 冒泡阶段

在找到被点击的 lv3 之后,事件向上传递,过程是 lv3 --> lv2 --> lv1,此时依次触发 lv3、lv2、lv1 的 click 事件,这个由内向外的触发过程就称为冒泡

再回看一下最常用的事件绑定方法的格式:

element.addEventListener(event, function, useCapture)
Salin selepas log masuk

这里面,useCapture 是个布尔值,用于定义事件是在冒泡阶段触发,还是在捕获阶段触发,默认值是 false,代表在冒泡时触发。

此时你就会知道上面那个例子里定义的 click 方法是在 捕获阶段 执行,那么返回的结果就是

lv1
lv2
lv3
Salin selepas log masuk

如果最上面的例子,onload 内容是这样的

 window.onload = () => {
        $('lv1').addEventListener("click",()=>{console.log('lv1')},false);
        $('lv2').addEventListener("click",()=>{console.log('lv2')},false);
        $('lv3').addEventListener("click",()=>{console.log('lv3')},false);
    };
Salin selepas log masuk

那么也就是说, click 事件在 冒泡阶段触发,返回的结果就是

lv3
lv2
lv1
Salin selepas log masuk

总结

冒泡和捕获的关系,只会出现在包含和被包含的结构中,兄弟关系是不会有这种关系的。
冒泡和捕获只是方向的不同而已。

Atas ialah kandungan terperinci JavaScript冒泡和捕获的知识介绍(附代码). Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Label berkaitan:
sumber:segmentfault.com
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan