1. 简介
闭包就是能够读取其他函数内部变量的函数。只有函数内部的子函数才能读取局部变
量,在本质上,闭包是函数内部和函数外部连接起来的桥梁。
当函数可以记住并访问所在词法作用域时,就产生了闭包,即使函数是在当前词法作
用域之外执行
2.定义
如果在一个内部函数里,对在外部作用域(但不是全局作用域)的变量进行引用,
那么内部函数就被认为是闭包(closure)。
3.特点
1.可以读取自身函数外部的变量(沿着作用域链寻找)先从自身开始查找,如果自身
没有才会继续往上级查找,自身如果拥有将直接调用。(哪个离的最近就用哪一
个)
2.延长内部变量的生命周期
3.函数b嵌套在函数a内部
4.函数a返回函数b
4.作用
在函数a执行完并返回后,闭包使得JavaScript的垃圾回收机制不会收回a所占用的资源,因为a
的内部函数b的执行需要依赖a中的变量,闭包需要循序渐进的过程。
5.构成
闭包由俩个部分构成:
- 函数
- 以及创建该函数的环境
6.应用场景
1.保护函数内的变量安全。函数a中只有函数b才能访问,而无法通过其他途径访问到,因此保
护了i的安全性。
2.在内存中维持一个变量
demo:
var test = (function() {
var a = 1;
function add(val){
a += val;
}
return {
add1() {
add(1);
},
add2() {
add(2);
},
result() {
return a;
}
}
})();
这种方式也叫作模块模式
7.缺点
滥用闭包会造成内存泄露,因为闭包中引用到的包裹函数中定义的变量都永远不会被释放,所
以我们应该在必要的时候,及时释放这个闭包函数
8.如何产生闭包
作用域应用的特殊情况,有两种表现:
1.函数作为参数被传递
2.函数作为返回值被返回
// 函数作为返回值
function create() {
const a = 100
return function () {
console.log(a)
}
}
const fn = create()
const a = 200
fn() // 100
// 函数作为参数被传递
function print(fn) {
const a = 200
fn()
}
const a = 100
function fn() {
console.log(a)
}
print(fn) // 100