JavaScript笔记-005闭包

90 阅读2分钟

闭包

变量的作用域

全局变量所有函数可以读取;

函数内部的局部变量,只有函数内部可以读取;

当需要得到函数内的局部变量时,可以通过闭包方式来实现;

闭包的定义

// func2 函数就是闭包
function func1() {
	var n = 999;
	function func2() {
		alert(n);
	}
	return func2;
}
var result = func1();
result();

闭包概念

闭包就是能够读取其他函数内部变量的函数。

由于在 Javascript 语言中,只有函数内部的子函数才能读取局部变量,因此可以把闭包简单理解成"定义在一个函数内部的函数"。

所以,在本质上,闭包就是将函数内部和函数外部连接起来的一座桥梁。

闭包的用途

// 1-可以读取函数内部的变量
// func2 作为闭包,提供外部访问 func1 内部变量的能力
function func1() {
	var n = 999;
	function func2() {
		alert(n);
	}
	return func2;
}
var result = func1();
result();

// 2-让这些变量的值始终保持在内存中
// 这里 func2 和 nAdd 函数都是闭包
function func1() {
	var n = 999;
	nAdd = function() {
		n = n + 1;
	}
	function func2() {
		alert(n);
	}
	return func2;
}
var result = func1();
result(); // 999
nAdd();
result(); // 1000

闭包注意事项

  • 由于闭包会使得函数中的变量都被保存在内存中,内存消耗很大,所以不能滥用闭包,否则会造成网页的性能问题,在 IE 中可能导致内存泄露。解决方法是,在退出函数之前,将不使用的局部变量全部删除。
  • 闭包会在父函数外部,改变父函数内部变量的值。所以,如果你把父函数当作对象(object)使用,把闭包当作它的公用方法(Public Method),把内部变量当作它的私有属性(private value),这时一定要小心,不要随便改变父函数内部变量的值。