JS闭包是什么?
首先,放一个概念:
函数 加 函数内部能访问到的局部变量 就组成了一个闭包
那闭包又有什么作用呢?
闭包常常用来「间接访问一个变量」。换句话说,「隐藏一个变量」。
通常做法是 暴露一个访问器(函数),让别人可以「间接访问」那个变量。
有这样一段代码:
var i = 'i am in windows'
var test = function(){
var a = 0;
var b = function(){
console.log(a)
}
return b
}
很明显 a 是 test 这个函数对象内的局部变量 而在其内部 �b 又引用了这个对象a 这就是一个闭包
a变量 和 b 函数对象组成了一个闭包
那为什么要test函数里要再套一个b函数呢?
是因为需要局部变量,所以才把 a 放在一个函数里,如果不把 a 放在一个函数里,a 就是一个全局变量了,达不到使用闭包的目的——隐藏变量。
有些人看到「闭包」这个名字,就一定觉得要用什么包起来才行。其实这是翻译问题,闭包的原文是 Closure,跟「包」没有任何关系。
所以函数套函数只是为了造出一个局部变量,跟闭包无关。
那为什么又要 return b 呢?
因为如果不 return,你就无法使用这个闭包。return b 的目的只是让外面可以访问到这个 b 函数。
所以 return b 只是为了 b 能被使用,也跟闭包无关。
下面看下 闭包的庐山真面目:
看到了吗 function scope 里面出现了Closure 和 Global
Closure里有 a 变量的值 也就是 0
那么我们是否可以猜测 我们在首行定义的全局变量 i 是不是就在Global这个 function scope 里面?
验证下
全局变量 i 确实就在 Global里面
其实,function scope内默认有个名为 Globe 的全局引用(有了这个引用,就可以直接调用 Globe 的属性或方法)
而在Closure里的变量或方法 外部是无法直接访问的
这就是 隐藏 了一个变量
by 潘小闲
参考资料: