0

0

javascript中闭包的概念是什么_它如何影响变量作用域?

狼影

狼影

发布时间:2026-01-13 16:07:47

|

261人浏览过

|

来源于php中文网

原创

闭包是函数与其词法环境的组合,需同时满足:存在引用外部局部变量的内部函数、该函数被返回或脱离原始上下文;var/let在循环闭包中因作用域机制不同导致输出差异;闭包会阻止捕获变量被垃圾回收,易引发内存泄漏。

javascript中闭包的概念是什么_它如何影响变量作用域?

闭包不是某种特殊函数,而是函数与其词法环境的组合——只要一个函数在定义时能访问其外层作用域中的变量,并且这个函数在定义之外被调用,就形成了闭包。

闭包产生的核心条件

必须同时满足三个条件:

  • 存在一个内部函数(function 或箭头函数)
  • 该内部函数引用了外部函数的局部变量(非全局、非参数传入)
  • 外部函数返回了这个内部函数(或以其他方式使它脱离原始执行上下文)

缺一不可。只定义不返回,或返回但没保存/调用,都不构成实际起效的闭包。

varlet 在闭包中的行为差异

循环中创建多个闭包时,变量声明方式直接影响结果:

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

飞书多维表格
飞书多维表格

表格形态的AI工作流搭建工具,支持批量化的AI创作与分析任务,接入DeepSeek R1满血版

下载
for (var i = 0; i < 3; i++) {
  setTimeout(() => console.log(i), 100); // 输出 3, 3, 3
}
for (let j = 0; j < 3; j++) {
  setTimeout(() => console.log(j), 100); // 输出 0, 1, 2
}

原因:var 声明的 i 是函数作用域共享的,所有定时器回调共用同一个 i;而 let 每次迭代都绑定独立的绑定记录(binding),每个闭包捕获的是各自迭代中的 j 值。

闭包导致的内存保留问题

闭包会阻止其词法环境中变量被垃圾回收,即使外部函数早已执行完毕:

  • 如果闭包长期存活(如绑定到全局对象、事件监听器、定时器),它所捕获的变量也会一直驻留内存
  • 特别危险的是捕获了大对象(如 document、大型数组、DOM 节点集合)
  • 调试时可通过 Chrome DevTools 的 Memory 面板 + Heap Snapshot 查看“Closure”条目下的 retained size

常见误用:addEventListener 中直接写匿名闭包却不提供 removeEventListener 清理路径,导致重复绑定+内存泄漏。

闭包本身没有“副作用”,但它的生命周期和捕获逻辑很容易被忽略——真正难的不是写出闭包,而是判断某个变量是否被意外长期持有。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

WorkBuddy
WorkBuddy

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

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

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

1057

2023.08.11

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

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

838

2023.11.06

chrome什么意思
chrome什么意思

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

1057

2023.08.11

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

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

838

2023.11.06

go语言闭包相关教程大全
go语言闭包相关教程大全

本专题整合了go语言闭包相关数据,阅读专题下面的文章了解更多相关内容。

152

2025.07.29

function是什么
function是什么

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

499

2023.08.04

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

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

166

2023.10.07

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

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

4330

2024.08.14

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

76

2026.03.11

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
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号