js函数闭包

闭包可以在函数外部访问函数内部定义的变量
例子一:直接访问会报错

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上卷,闭包》

おすすめ

転載: blog.csdn.net/qq_45989814/article/details/121846123