JS闭包总结
先上一段代码:
---------------------------------------------------------
function bar(){
var i = 0;
return function(){
console.log(i++);
}
}
var foo = bar();
foo();
foo();
---------------------------------------------------------
代码的执行顺序如下:
---------------------------------------------------------
1.先初始化全局环境global environment
1.outer reference = null
2.初始化环境记录
bar():<function>
bar.scope = global environment
//scope保存函数所在的词法环境
foo:undefined
2.执行全局代码到 var foo = bar();
3.初始化bar环境
1.outer reference = bar.scope = global environment
2.初始化环境记录
i:undefined
4.执行bar()函数代码
1.i = 0
2.在bar环境中创建一个匿名函数(anonymous function),且其scope为 bar environment
5.执行 var foo = bar()
foo = 匿名函数
// var foo = function(){}
6.执行到foo();先初始化foo环境
1.outer reference = bar environment
2.初始化环境记录
空
7.执行foo()函数代码
console.log(i++);
8.再次执行到foo();再次初始化foo环境
1.outer reference = bar environment
2.初始化环境记录
空
9.执行foo()函数代码
console.log(i++);
什么是闭包
闭包由函数和与其相关的环境组合而成
上面bar函数返回的匿名函数就是一个闭包,其scope属性保存着外部的环境bar environment,且返回的函数引用着bar environment中的i变量,所以即使在bar函数执行完之后,其词法环境bar environment仍然存在,并没有被释放。
广义上说,所有的JS函数可以称作闭包,因为所有的JS函数在创建时其scope属性都保存当前的词法环境