闭包的作用:
让函数内部的局部变量,在函数执行完成后,让外部能够操作这个变量(延长了函数内部的局部变量的生命周期)
在js中,内部作用域可以访问外部作用域
为了某些操作,需要在外部操作内部作用域的变量------通过闭包来进行
function fn1(){
var i = 0
return function(){
i++
console.log(i)
}
}
var ret = fn1()
ret()//i++
ret()//i++
为什么在fn1 函数执行完成后,依然可以操作局部变量i呢?
这时候闭包就产生了巨大作用
使用Chrome浏览器:
在fn1即将执行的时候,fn1会进行初始化
变量提前声明,函数提前执行定义
所以fn2已经提前执行定义了,编译器发现fn2使用到了外部fn1函数的变量a,为了能够让fn2正常使用,所以就会构造一个闭包对象。放在fn2函数中,将要使用外部变量保存一份(地址)
然后通过外部函数,将内部函数返回给全局作用域(一个例子),然后执行这个内部函数(存在一个闭包对象),进行执行内部函数,内部函数发现a变量不在当前的作用域中,于是去找闭包对象,闭包对象提前保存了这个对象。所以可以直接的使用和操作(内部函数怎么操作就怎么操作)。全局中没法直接对这个变量进行操作。
作用:
1.将一个函数作为另外一个函数的返回值
2.将函数传递过去给别人使用
针对作用1解释
针对作用2解释
也就是说内部函数通过一个闭包对象,保存了需要使用的变量或者函数。在使用的时候从闭包对象中拿出来即可。
匿名函数无法查看到闭包对象
在作用2中:将setTimeOut函数中传递的方法,拿出来才能够看到闭包对象,如果直接传递一个匿名函数的时候,无法在Chrome中查看到这个闭包对象的,但是依然可以使用闭包对象。
闭包的个人理解:
闭包就是内部函数构建了一个闭包对象
这个闭包对象保存了 需要使用的变量(外部函数)
内部函数返回给了,这样内部函数就可以通过闭包对象直接访问需要的变量了