0

0

javascript闭包原理_怎样避免内存泄漏

夢幻星辰

夢幻星辰

发布时间:2026-01-08 17:17:30

|

195人浏览过

|

来源于php中文网

原创

闭包是函数与其词法作用域的组合,通过持有对外部变量的引用使其不被垃圾回收;易致内存泄漏的是闭包意外长期持有大对象、DOM节点或全局引用。

javascript闭包原理_怎样避免内存泄漏

闭包是怎么把变量“关”住的

闭包不是语法结构,而是函数与其词法作用域的组合。只要一个函数在定义它的作用域外部被调用,且访问了该作用域里的变量,就形成了闭包。function outer() { const x = 1; return function inner() { return x; }; } 中的 inner 就是闭包——它持有对 x 的引用,哪怕 outer 已执行完毕,x 也不能被垃圾回收。

哪些闭包容易导致内存泄漏

真正引发内存泄漏的,从来不是闭包本身,而是闭包意外持有了大对象、DOM 节点或全局引用,且长期不释放。常见场景包括:

  • setTimeoutsetInterval 回调中引用了外部大数组或 DOM 元素,定时器未清除
  • 事件监听器(如 addEventListener)使用匿名闭包函数,但忘记调用 removeEventListener
  • 将闭包赋值给全局变量(比如 window.cacheFn = function() { ... }),而该闭包又引用了页面中已卸载的 DOM 节点
  • 在单页应用(SPA)中,组件销毁后,闭包仍通过回调、Promise 微任务或未 resolve 的 Promise 持有对旧组件实例的引用

怎么写闭包才不容易漏内存

关键不是不用闭包,而是控制引用生命周期。实操建议如下:

零沫AI工具导航
零沫AI工具导航

零沫AI工具导航-AI导航新标杆,探索全球实用AI工具

下载
  • 用具名函数代替匿名函数注册事件,方便后续精准移除:
    function handleClick() { console.log(this.id); }<br>element.addEventListener('click', handleClick);<br>// 销毁时:<br>element.removeEventListener('click', handleClick);
  • 在组件 unmount 或元素 remove 前,手动清理定时器:
    let timerId;<br>function start() {<br>  timerId = setTimeout(() => { /* ... */ }, 1000);<br>}<br>function cleanup() {<br>  clearTimeout(timerId);<br>  timerId = null;<br>}
  • 避免在闭包中直接引用整个 DOM 节点树;改用 ID、dataset 或轻量属性缓存必要信息:
    const el = document.getElementById('list');<br>const listId = el.id; // 而不是闭包里一直拿着 el</br>return function() { return document.getElementById(listId); };
  • 对 Promise 链中可能滞留的闭包,用 .finally() 或显式置空引用:
    let dataRef = null;<br>fetch('/api').then(res => res.json()).then(json => {<br>  dataRef = json;<br>}).finally(() => { dataRef = null; });

Chrome DevTools 怎么确认是不是闭包引起的泄漏

靠猜没用,得看堆快照(Heap Snapshot)。操作路径:打开 DevTools → Memory 面板 → “Take heap snapshot” → 在筛选框输入 (closure) → 展开看哪些闭包占用了大量 Shallow Size,再点进去看 retaining path(保留路径)。

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

重点关注:

  • 闭包是否出现在 WindowglobalThis 下(说明被全局持有)
  • retaining path 中是否包含已移除的 HTMLDivElementText 等节点
  • 是否有重复出现的闭包(比如每次渲染都新建但未清理)
真正难排查的,往往是多个小闭包叠加引用了一个大对象,最后谁都不肯放手。这时候就得顺着 retaining path 一层层查,而不是盯着闭包函数本身。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

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

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

1059

2023.08.11

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

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

840

2023.11.06

chrome什么意思
chrome什么意思

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

1059

2023.08.11

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

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

840

2023.11.06

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

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

562

2023.09.20

全局变量怎么定义
全局变量怎么定义

本专题整合了全局变量相关内容,阅读专题下面的文章了解更多详细内容。

95

2025.09.18

python 全局变量
python 全局变量

本专题整合了python中全局变量定义相关教程,阅读专题下面的文章了解更多详细内容。

106

2025.09.18

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

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

443

2023.07.18

TypeScript类型系统进阶与大型前端项目实践
TypeScript类型系统进阶与大型前端项目实践

本专题围绕 TypeScript 在大型前端项目中的应用展开,深入讲解类型系统设计与工程化开发方法。内容包括泛型与高级类型、类型推断机制、声明文件编写、模块化结构设计以及代码规范管理。通过真实项目案例分析,帮助开发者构建类型安全、结构清晰、易维护的前端工程体系,提高团队协作效率与代码质量。

3

2026.03.13

热门下载

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

精品课程

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

共58课时 | 6万人学习

TypeScript 教程
TypeScript 教程

共19课时 | 3.4万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.6万人学习

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

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