2

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 能被使用,也跟闭包无关。

下面看下 闭包的庐山真面目:

clipboard.png

看到了吗 function scope 里面出现了Closure 和 Global

Closure里有 a 变量的值 也就是 0

那么我们是否可以猜测 我们在首行定义的全局变量 i 是不是就在Global这个 function scope 里面?

验证下

clipboard.png

全局变量 i 确实就在 Global里面

其实,function scope内默认有个名为 Globe 的全局引用(有了这个引用,就可以直接调用 Globe 的属性或方法)

而在Closure里的变量或方法 外部是无法直接访问的

这就是 隐藏 了一个变量

by 潘小闲

参考资料:JS中的闭包是什么

同步github


潘小闲
146 声望9 粉丝

清教徒 驴友