0

0

JavaScript DOM 事件:事件流与事件委托机制

狼影

狼影

发布时间:2025-10-30 14:23:01

|

1011人浏览过

|

来源于php中文网

原创

事件流包含捕获、目标和冒泡三个阶段,事件从window开始向下传播至目标元素再向上冒泡;2. 可通过addEventListener的第三个参数指定在捕获或冒泡阶段监听事件;3. 使用event.stopPropagation()阻止事件传播,stopImmediatePropagation() additionally阻止同元素其他监听器执行;4. 事件委托利用冒泡机制将事件绑定到父元素处理子元素事件,减少内存占用并支持动态添加的元素;5. 需通过e.target准确判断事件源,并注意并非所有事件都冒泡,如focus、blur需用focusin/focusout替代。掌握这些机制可提升代码性能与维护性。

javascript dom 事件:事件流与事件委托机制

在 JavaScript 中,DOM 事件是用户与网页交互的核心机制。理解事件流和事件委托,有助于写出更高效、可维护的事件处理代码。

事件流:事件的传播过程

当用户触发一个 DOM 事件(如点击按钮),该事件并不会只作用于目标元素,而是在 DOM 树中经历三个阶段的传播过程:

  • 捕获阶段(Capture Phase):事件从 window 开始,逐级向下传递,经过 document、html、body,直到目标元素的父节点为止。这个阶段主要用于监听外层元素对内部事件的预处理。
  • 目标阶段(Target Phase):事件到达绑定事件的目标元素本身,此时事件被真正触发。
  • 冒泡阶段(Bubbling Phase):事件从目标元素开始,逐级向上传播回 window,路径与捕获相反。大多数事件默认在此阶段被处理。

可以通过 addEventListener 的第三个参数控制事件监听的阶段:

element.addEventListener('click', handler, true); // 捕获阶段监听
element.addEventListener('click', handler, false); // 冒泡阶段监听(默认)

阻止事件传播

有时不希望事件继续传播,可以使用以下方法:

立即学习Java免费学习笔记(深入)”;

  • event.stopPropagation():阻止事件继续在 DOM 树中传播,但不影响当前元素其他监听器的执行。
  • event.stopImmediatePropagation():除了阻止传播,还阻止当前元素上其他同类型事件监听器的执行。

例如,点击子元素时,如果不希望触发父级的 click 事件,可在子元素事件处理器中调用 stopPropagation。

新思创OA办公自动化系统增强版
新思创OA办公自动化系统增强版

中国最实用的办公自动化系统,全面提升单位的工作效率和质量,整合企业资源,规范办公流程,加快信息流通,提高办公效率,降低办公成本,通过提高执行力来完善管理,从而提升企业竞争力 含公告通知、文件传送、电子通讯薄、日程安排、工作日记、工作计划、个人(公共)文件柜、网上申请和审批、电子邮件、手机短信、个人考勤、知识管理、人事管理、车辆管理、会议管理、印信管理、网上填报、规章制度、论坛、网络会议、语音聊天、

下载

事件委托:利用事件冒泡优化性能

事件委托是一种利用事件冒泡机制,将事件监听器绑定到父元素来处理子元素事件的技术。它特别适用于动态内容或大量子元素的场景。

比如有一个无序列表 ul,包含多个 li 项,未来可能动态添加新的 li。如果为每个 li 单独绑定事件,不仅繁琐,新增元素还需重新绑定。

使用事件委托,只需为 ul 绑定一次事件:

const list = document.querySelector('ul');
list.addEventListener('click', function(e) {
  if (e.target.tagName === 'LI') {
    console.log('Clicked on:', e.target.textContent);
  }
});

这样,无论 li 是何时添加的,点击都会通过冒泡被 ul 捕获并正确处理。

事件委托的优势与注意事项

  • 减少内存占用:避免为多个元素重复绑定事件监听器。
  • 支持动态元素:无需为新插入的 DOM 节点重新绑定事件。
  • 注意事件源判断:必须通过 e.target 准确识别实际触发事件的元素,防止误处理。
  • 并非所有事件都冒泡:如 focus、blur 等不冒泡,可用 focusin/focusout 替代。

基本上就这些。掌握事件流和事件委托,能让你的事件处理逻辑更清晰、性能更优。关键是理解冒泡机制,并善用 e.target 进行事件代理判断。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
if什么意思
if什么意思

if的意思是“如果”的条件。它是一个用于引导条件语句的关键词,用于根据特定条件的真假情况来执行不同的代码块。本专题提供if什么意思的相关文章,供大家免费阅读。

775

2023.08.22

c语言const用法
c语言const用法

const是关键字,可以用于声明常量、函数参数中的const修饰符、const修饰函数返回值、const修饰指针。详细介绍:1、声明常量,const关键字可用于声明常量,常量的值在程序运行期间不可修改,常量可以是基本数据类型,如整数、浮点数、字符等,也可是自定义的数据类型;2、函数参数中的const修饰符,const关键字可用于函数的参数中,表示该参数在函数内部不可修改等等。

530

2023.09.20

console接口是干嘛的
console接口是干嘛的

console接口是一种用于在计算机命令行或浏览器开发工具中输出信息的工具,提供了一种简单的方式来记录和查看应用程序的输出结果和调试信息。本专题为大家提供console接口相关的各种文章、以及下载和课程。

415

2023.08.08

console.log是什么
console.log是什么

console.log 是 javascript 函数,用于在浏览器控制台中输出信息,便于调试和故障排除。想了解更多console.log的相关内容,可以阅读本专题下面的文章。

504

2024.05.29

function是什么
function是什么

function是函数的意思,是一段具有特定功能的可重复使用的代码块,是程序的基本组成单元之一,可以接受输入参数,执行特定的操作,并返回结果。本专题为大家提供function是什么的相关的文章、下载、课程内容,供大家免费下载体验。

482

2023.08.04

js函数function用法
js函数function用法

js函数function用法有:1、声明函数;2、调用函数;3、函数参数;4、函数返回值;5、匿名函数;6、函数作为参数;7、函数作用域;8、递归函数。本专题提供js函数function用法的相关文章内容,大家可以免费阅读。

163

2023.10.07

DOM是什么意思
DOM是什么意思

dom的英文全称是documentobjectmodel,表示文件对象模型,是w3c组织推荐的处理可扩展置标语言的标准编程接口;dom是html文档的内存中对象表示,它提供了使用javascript与网页交互的方式。想了解更多的相关内容,可以阅读本专题下面的文章。

3303

2024.08.14

DOM是什么意思
DOM是什么意思

dom的英文全称是documentobjectmodel,表示文件对象模型,是w3c组织推荐的处理可扩展置标语言的标准编程接口;dom是html文档的内存中对象表示,它提供了使用javascript与网页交互的方式。想了解更多的相关内容,可以阅读本专题下面的文章。

3303

2024.08.14

Python 自然语言处理(NLP)基础与实战
Python 自然语言处理(NLP)基础与实战

本专题系统讲解 Python 在自然语言处理(NLP)领域的基础方法与实战应用,涵盖文本预处理(分词、去停用词)、词性标注、命名实体识别、关键词提取、情感分析,以及常用 NLP 库(NLTK、spaCy)的核心用法。通过真实文本案例,帮助学习者掌握 使用 Python 进行文本分析与语言数据处理的完整流程,适用于内容分析、舆情监测与智能文本应用场景。

10

2026.01.27

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Django 教程
Django 教程

共28课时 | 3.6万人学习

【web前端】Node.js快速入门
【web前端】Node.js快速入门

共16课时 | 2万人学习

550W粉丝大佬手把手从零学JavaScript
550W粉丝大佬手把手从零学JavaScript

共1课时 | 0.3万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号