闭包
JS中的闭包是一个我们经常遇到的名词,到底什么是闭包?为什么我们要使用闭包?又该如何使用闭包呢?
为什么我们需要闭包
首先来看一个例子,我们来实现一个计数器。
1 | var counter = 0; |
现在我们已经达到了目的,可是问题来了,代码中的任何一个函数都可以随意改变counter
的值,所以这个计数器并不完美。那我们把counter
放在add
函数里面不就好了么?
1 | function add() { |
所以这样做的话,每次调用add
函数,counter
的值都要被初始化为0,还是达不到我们的目的。
如何使用闭包
所以这时候我们就要用闭包去解决这个问题了,先看代码。
1 | var add = (function () { |
这时候我们完美实现了计数器。这段非常精简,可以拆分成如下等价代码。
1 | function outerFunction () { |
这时候的add
就形成了一个闭包。一个闭包由两部分组成,函数和创建该函数的环境。环境是由环境中的局部变量组成的。对于闭包add
来说,它由函数innerFunction
和变量counter
组成,所以这时候add
是可以访问变量counter
的。
总结
所以闭包的功能就是使一个函数能访问另一个函数作用域中的变量。形成闭包之后,该变量不会被垃圾回收机制回收。
闭包的原理其实还是作用域。
使用闭包的优点是可以避免全局变量污染,缺点是容易造成内存泄露。