Day25 - Event Capture, Propagation, Bubbling and Once

本文介绍JavaScript30挑战中的第25天训练内容——DOM事件机制。重点讲解事件捕获、事件冒泡及单次执行事件的概念,并通过示例代码演示如何在不同层级的元素上注册事件监听器。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

本文出自:春哥个人博客:http://www.liyuechun.org
作者:©黎跃春-追时间的人
简介:JavaScript30Wes Bos 推出的一个 30 天挑战。项目免费提供了 30 个视频教程、30 个挑战的起始文档和 30 个挑战解决方案源代码。目的是帮助人们用纯 JavaScript 来写东西,不借助框架和库,也不使用编译器和引用。现在你看到的是这系列指南的第 25 篇。完整中文版指南及视频教程在 从零到壹全栈部落

效果图

第25天的训练是学习DOM的事件机制,主要包括事件捕获,事件冒泡,单次执行事件。

源代码

addEventListener参考文档

 <script>
        let divs = document.querySelectorAll('div');
        let one = document.querySelector('.one');
        let two = document.querySelector('.two');
        let three = document.querySelector('.three');
        divs.forEach(div => div.addEventListener('click', logText, {
            once: true,
            capture: false
        }));

        // one.addEventListener('click', logText1, {
        //     // capture: true
        // });
        // two.addEventListener('click', logText2, {
        //     // capture: true
        // });
        // three.addEventListener('click', logText3, {
        //     capture: true
        // });


        function logText(e) {
            console.log(this.classList.value);
            // e.stopPropagation();
        }

        function logText1(e) {
            console.log(this.classList.value);
            // e.stopPropagation();
        }

        function logText2(e) {
            console.log(this.classList.value);
            // e.stopPropagation();
        }

        function logText3(e) {
            console.log(this.classList.value);
            e.stopPropagation();
        }

</script>

同时也看一下HTML的文档结构,对于事件机制的理解也很重要:

<div class="one">
    <div class="two">
        <div class="three">
        </div>
    </div>
</div>
  • EventTarget.addEventListener('eventName',callback,option):元素的事件注册方法,接收三个参数,第一个参数为事件的名称(点击click、双击dbclick、改变change等),第二个参数是该事件的回调函数,也称为监听器,第三个参数为事件注册的选项对象,通常会包含两个配置项(是否事件捕获capture以及单次执行once事件,它们两个的默认值都是false)。
  • 当我们点击class="three"div的时候,我们也相当于同时点击了class="two"class="one"
  • e.stopPropagation();是否停止冒泡,如果调用了这个方法,就不会触发父组建的方法。

源码下载

Github Source Code

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

黎跃春

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值