欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 房产 > 建筑 > 【JS重点09】JS闭包(面试重点)

【JS重点09】JS闭包(面试重点)

2025/2/23 20:16:15 来源:https://blog.csdn.net/qq_67896626/article/details/139578077  浏览:    关键词:【JS重点09】JS闭包(面试重点)

目录

一:闭包概览

1 闭包是什么

2 闭包作用

二:闭包应用

实现数据私有


本文核心目标:阅读完本文能说出什么是闭包,闭包作用以及如何利用闭包

一:闭包概览

1 闭包是什么

闭包(closure)是一个函数以及其捆绑的周边环境状态(lexical environment词法环境)的引用的组合。换而言之,闭包让开发者可以从内部函数访问外部函数的作用域。在 JavaScript 中,闭包会随着函数的创建而被同时创建。

简言之,闭包=内部函数+外部函数变量

2 闭包作用

封闭数据,使得外部也可以访问函数内部的变量

闭包典型示例:

<script>function outer() {let a = 100function inner() {console.log(a);}return inner}const gb = outer()gb()
</script>
//上面代码解析:
outer()===inner ===function inner(){}
gb() === function inner(){}
从全局作用域中使用的gb(),进而调用了函数内部变量

二:闭包应用

实现数据私有

<script>function outer() {let a = 1function inner() {a++console.log(a);}return inner}const gb = outer()gb()</script>

需求:记录outer函数被调用的次数

如果将let a = 1声明在全局作用域中,很容易被修改且容易混淆;但通过闭包方式,可以从gb()出发能够找到变量a,所以就可以实现记录,而不被垃圾回收机制清除;

同时,因为变量a是位于局部作用域中,本应运行完后清除,但是因为闭包的缘故没有实现内存回收;所以造成了内存泄漏问题

断点调试

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com

热搜词