闭包可以在函数外部访问函数内部定义的变量 例子一:直接访问会报错
function fn1(){
var a="3"
}
console.log(a)
Uncaught ReferenceError: a is not defined
例子二:在函数中返回一个函数,并且外部用变量来接收,可以访问到foo函数中的变量a
function foo(){
var a='2'
function bar(){
console.log(a)
}
return bar;
}
var baz=foo();
baz(); // 2
这是因为函数bar()的词法作用域能访问foo()的内部作用域。然后我们将bar()函数本身当作一个值类型进行传递。在这个例子中,我们将bar所引用的函数对象本身当做返回值。 在foo()执行后,其返回值(也就是内部的bar()函数)赋值给变量baz并且调用baz(),实际上只是通过不同的标识符引用了内部的函数bar(). bar()显然可以被正常执行,在这个例子中,它在自己定义的词法作用域以外的地方执行。 在foo()执行后,通常会期待foo()的整个内部作用域被销毁,因为我们知道引擎有垃圾回收机制来释放不再使用的内存空间。同于看上去foo()的内容不会再被使用,所以很自然的会考虑对其进行回收。 而闭包的神奇之处就在于可以阻止这件事的发生。事实上内部作用域依然存在,因此没有被回收。还在函数bar()在使用这个内部作用域。
摘自《你不知道的JavaScript上卷,闭包》
|