0

0

什么是事件处理_JavaScript中如何添加和移除事件监听器

夢幻星辰

夢幻星辰

发布时间:2026-01-05 20:33:09

|

249人浏览过

|

来源于php中文网

原创

事件监听器必须用相同函数引用和options才能精准移除,匿名函数无法清除;{once:true}自动卸载;推荐用AbortController统一管理批量监听器。

什么是事件处理_javascript中如何添加和移除事件监听器

事件监听器不是“绑定”在元素上就一劳永逸的——添加之后必须能精准移除,否则容易引发内存泄漏或重复触发。

addEventListener 和 removeEventListener 必须用同一个函数引用

这是最常踩的坑:用匿名函数添加,就永远无法移除。

  • addEventListener 的第二个参数必须是**函数引用**,不能是调用结果(比如 handler())或匿名函数(比如 () => {}
  • removeEventListener 的前两个参数必须与 addEventListener 完全一致:相同类型、相同函数引用、相同 options
  • 如果用了 { once: true },监听器执行后自动卸载,无需手动移除
const btn = document.getElementById('my-btn');
function handleClick() {
  console.log('clicked');
}
btn.addEventListener('click', handleClick);
// ✅ 可以成功移除
btn.removeEventListener('click', handleClick);

// ❌ 下面这行不会生效,因为是不同函数引用 btn.addEventListener('click', () => console.log('anonymous')); btn.removeEventListener('click', () => console.log('anonymous')); // 无效

事件监听器的 options 参数影响 removeEventListener 是否生效

captureoncepassive 这些选项不是“附加信息”,而是监听器签名的一部分。移除时漏掉或写错,就匹配不上。

  • 如果添加时用了 { capture: true },移除时也必须传 { capture: true }
  • passiveonce 同理,哪怕只是想移除,也要原样复现
  • 浏览器不会报错,但 removeEventListener 静默失败
const el = document.querySelector('.scrollable');
function onScroll() { /* ... */ }

el.addEventListener('scroll', onScroll, { passive: true }); // ✅ 正确移除 el.removeEventListener('scroll', onScroll, { passive: true });

// ❌ 错误:没传 passive,匹配失败 el.removeEventListener('scroll', onScroll);

用 AbortController 移除一批监听器(现代推荐方式)

当需要批量管理、或在组件销毁/路由切换时统一清理,用 AbortSignal 比手写一堆 removeEventListener 更可靠。

Mutiny
Mutiny

无代码AI平台,帮助营销人员将漏斗需求转化为收入。

下载

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

  • 一个 AbortController 实例可控制多个监听器
  • 调用 controller.abort() 后,所有关联监听器自动卸载
  • 兼容性良好(Chrome 88+、Firefox 89+、Safari 15.4+,旧环境可用 polyfill)
const controller = new AbortController();
const signal = controller.signal;

element.addEventListener('click', handler1, { signal }); element.addEventListener('input', handler2, { signal }); element.addEventListener('submit', handler3, { signal });

// 一次性清理全部 controller.abort(); // 所有带该 signal 的监听器立即失效

最容易被忽略的是:移除监听器这件事本身,往往比添加更需要设计——尤其在单页应用中,组件反复挂载/卸载时,不清理或清理不全,会积累大量“幽灵监听器”。别依赖垃圾回收,主动控制才是关键。

相关专题

更多
chrome什么意思
chrome什么意思

chrome是浏览器的意思,由Google开发的网络浏览器,它在2008年首次发布,并迅速成为全球最受欢迎的浏览器之一。本专题为大家提供chrome相关的文章、下载、课程内容,供大家免费下载体验。

760

2023.08.11

chrome无法加载插件怎么办
chrome无法加载插件怎么办

chrome无法加载插件可以通过检查插件是否已正确安装、禁用和启用插件、清除插件缓存、更新浏览器和插件、检查网络连接和尝试在隐身模式下加载插件方法解决。更多关于chrome相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

721

2023.11.06

堆和栈的区别
堆和栈的区别

堆和栈的区别:1、内存分配方式不同;2、大小不同;3、数据访问方式不同;4、数据的生命周期。本专题为大家提供堆和栈的区别的相关的文章、下载、课程内容,供大家免费下载体验。

380

2023.07.18

堆和栈区别
堆和栈区别

堆(Heap)和栈(Stack)是计算机中两种常见的内存分配机制。它们在内存管理的方式、分配方式以及使用场景上有很大的区别。本文将详细介绍堆和栈的特点、区别以及各自的使用场景。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

567

2023.08.10

java成品网站源码资源大全
java成品网站源码资源大全

本专题整合了java成品网站源码相关内容,阅读专题下面的文章了解更多详细内容。

2

2026.01.08

java过滤器教程大全
java过滤器教程大全

本专题整合了java过滤器相关教程,阅读专题下面的文章了解更多详细内容。

3

2026.01.08

作业帮网页版入口地址大全
作业帮网页版入口地址大全

本专题整合了作业帮网页版地址整理,阅读专题下面的文章了解更多详细内容。

2

2026.01.08

学习通网页版入口地址大全
学习通网页版入口地址大全

本专题整合了学生通网页版入口相关整理,阅读专题下面的文章了解更多详细内容。

2

2026.01.08

C++ 高性能计算与并行编程
C++ 高性能计算与并行编程

本专题专注于 C++ 在高性能计算(HPC)与并行编程中的应用,涵盖多线程、并发数据处理、OpenMP、MPI、GPU加速等技术。通过实际案例,帮助开发者掌握 如何利用 C++ 进行大规模数据计算和并行处理,提高程序的执行效率,适应高性能计算与数据密集型应用场景。

6

2026.01.08

热门下载

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

精品课程

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

共58课时 | 3.4万人学习

TypeScript 教程
TypeScript 教程

共19课时 | 2万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 2.8万人学习

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

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