JS中的闭包是一个咱们常常遇到的名词,到底什么是闭包?为何咱们要使用闭包?又该如何使用闭包呢?javascript
首先来看一个例子,咱们来实现一个计数器。java
var counter = 0; function add() { return counter += 1; } add(); add(); add();// 计数器如今为 3
如今咱们已经达到了目的,但是问题来了,代码中的任何一个函数均可以随意改变counter
的值,因此这个计数器并不完美。那咱们把counter
放在add
函数里面不就行了么?闭包
function add() { var counter = 0; return counter += 1; } add(); add(); add();// 本意是想输出 3, 但输出的都是 1
因此这样作的话,每次调用add
函数,counter
的值都要被初始化为0,仍是达不到咱们的目的。函数
因此这时候咱们就要用闭包去解决这个问题了,先看代码。code
var add = (function () { var counter = 0; return function () {return counter += 1;} })(); add(); add(); add();// 计数器为 3
这时候咱们完美实现了计数器。这段很是精简,能够拆分红以下等价代码。ip
function outerFunction () { var counter = 0; function innerFunction (){ return counter += 1; } return innerFunction; } var add = outerFunction(); add(); add(); add();// 计数器为 3
这时候的add
就造成了一个闭包。一个闭包由两部分组成,函数和建立该函数的环境。环境是由环境中的局部变量组成的。对于闭包add
来讲,它由函数innerFunction
和变量counter
组成,因此这时候add
是能够访问变量counter
的。内存
因此闭包的功能就是使一个函数能访问另外一个函数做用域中的变量。造成闭包以后,该变量不会被垃圾回收机制回收。作用域
闭包的原理其实仍是做用域。io
使用闭包的优势是能够避免全局变量污染,缺点是容易形成内存泄露。function