0

0

javascript闭包是什么_闭包在实际开发中有什么用处【教程】

夢幻星辰

夢幻星辰

发布时间:2026-01-21 19:47:13

|

145人浏览过

|

来源于php中文网

原创

闭包是javascript中函数记住并访问其定义时词法作用域的能力。它需满足三条件:外层函数含局部变量、内部定义函数、外层返回该函数;用于封装私有状态、保存上下文、函数工厂、缓存结果;常见坑是循环变量共享与内存泄漏。

javascript闭包是什么_闭包在实际开发中有什么用处【教程】

闭包 是 JavaScript 中一个函数“记住并持续访问其定义时所在词法作用域”的能力——哪怕这个函数在别的地方被调用,它依然能读写外层函数的变量。

它不是语法糖,也不是高级技巧,而是你每天都在用却可能没意识到的底层机制:比如 setTimeout 回调里能访问 for 循环变量、ReactuseState 能保持状态、防抖函数 能记住上一次定时器 ID……全靠闭包撑着。


怎么一眼认出闭包?看这三步

只要同时满足以下三点,就是闭包:

  • 有一个外层函数(含局部变量)
  • 内部定义了一个函数(不一定要命名)
  • 外层函数返回了这个内部函数(或以其他方式让内部函数逃逸出作用域)

典型信号:return function() { ... }addEventListener('click', function() { ... }) —— 只要函数里用了外层的 let/const 变量,且该函数后续还会执行,基本就是闭包。

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

Dora
Dora

创建令人惊叹的3D动画网站,无需编写一行代码。

下载

为什么用闭包?不是为了炫技,而是解决这几个硬需求

闭包不是可选项,是某些场景下唯一干净的解法:

  • 封装私有状态:比如计数器里的 count,外部无法直接改,只能通过 increment() 操作
  • 保存上下文环境:事件监听中,每个按钮回调需要记住自己的 id 或配置,不用闭包就得靠 data- 属性或全局映射表
  • 实现函数工厂:比如生成不同超时时间的 debounce 函数,debounce(fn, 300)debounce(fn, 1000) 各自维护独立的 timerId
  • 缓存计算结果(memoization)factorial(10) 算过一次,下次直接返回,靠闭包把 cache 锁在函数内部

闭包最常踩的坑:内存泄漏和变量共享

闭包本身无害,但用错就容易翻车:

  • 循环中创建闭包,所有回调共用同一个变量:用 var 声明循环变量时,for (var i = 0; i console.log(i), 0) 全输出 3;改用 let 或包裹 IIFE 才能隔离
  • 无意长期持有大对象引用:比如在闭包里存了整个 DOM 节点或 JSON 数据,又没清理,GC 就收不走
  • 误以为闭包能“冻结”值:闭包捕获的是变量的引用,不是快照。如果外层变量被改了(比如 obj.name = 'new'),闭包里看到的也是新值

什么时候该主动用闭包?看这几个信号

遇到以下情况,别绕弯,直接上闭包:

  • 你需要一个“带记忆”的函数,比如 createLogger(prefix) 返回带前缀的日志函数
  • 你在写工具函数,希望用户传入配置后,得到一个预设好行为的函数(如 createUrlBuilder(baseUrl)
  • 你要给多个元素绑定事件,又不想污染全局或重复查 DOM
  • 你发现正在反复写 const config = {...}; return () => {...} 这种模式 —— 那就是在手写闭包

真正难的不是写闭包,而是判断「该不该用」以及「用完要不要释放」。很多 bug 不是闭包本身的问题,是忘了它会让变量活得比预期久一点。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

455

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

546

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

334

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

82

2025.09.10

counta和count的区别
counta和count的区别

Count函数用于计算指定范围内数字的个数,而CountA函数用于计算指定范围内非空单元格的个数。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

203

2023.11.20

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

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

562

2023.09.20

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

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

151

2025.07.29

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

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

420

2023.08.08

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

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

3

2026.03.11

热门下载

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

精品课程

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

共58课时 | 6万人学习

国外Web开发全栈课程全集
国外Web开发全栈课程全集

共12课时 | 1万人学习

React核心原理新老生命周期精讲
React核心原理新老生命周期精讲

共12课时 | 1.1万人学习

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

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