-
官方概念:一个函数对周围状态的引用捆绑在一起, 内层函数中访问到其外层函数的作用域
-
简单理解: 闭包 = 内层函数 + 引用的外层函数变量
-
普通函数与闭包对比
// 普通函数引用外部变量
var temp = 0;
function fun() {
temp++
console.log(`外层函数变量被使用${temp}次了`)
}
fun()
// 注意:
// 此时如果改变变量temp的值,函数里面也会被改变,变量不是函数私有
// 闭包的写法
function outer() {
let consts = 0;
function fun() {
consts++
console.log(`外层函数变量被使用${consts}次了`)
}
return fun
}
const result = outer()
result()
result()
// *闭包一定使用return吗
// 外部使用变量时才会使用return,外部只能使用不能修改;
// *闭包一定会引起内存泄漏吗
// 不一定:当外部调用的函数不销毁时,闭包才会引起内存泄露
// *闭包实现数据私有:
// 使用闭包实现了数据私有:外部不能修改,也不能读取,return之后也只能读取,不能修改