JS闭包

JS闭包是什么?git

首先,放一个概念:github

函数 加 函数内部能访问到的局部变量 就组成了一个闭包windows

那闭包又有什么做用呢?闭包

闭包经常用来「间接访问一个变量」。换句话说,「隐藏一个变量」。函数

一般作法是 暴露一个访问器(函数),让别人能够「间接访问」那个变量。spa

有这样一段代码:翻译

var i = 'i am in windows'

var test = function(){

     var a = 0;

      var  b = function(){ 

           console.log(a)

       }

       return b

}

很明显 a 是 test 这个函数对象内的局部变量 而在其内部 b 又引用了这个对象a 这就是一个闭包code

a变量 和 b 函数对象组成了一个闭包对象

那为何要test函数里要再套一个b函数呢?blog

是由于须要局部变量,因此才把 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

相关文章
相关标签/搜索