js闭包

闭包是指有权访问另一个 函数作用域中的变量的函数。创建闭包的常见方式,就是在一个函数内部创建另一个函数。

如:

var a = 100;
function addNum(){
	var a=0;
	return function(){
		a++;
		console.log(a)
	}
}
var plusNum=addNum();
plusNum()  //打印1
a = 200;   //外部重名变量丝毫不影响私有变量
plusNum()  //打印2

用途:

1.为防止重要全局变量被污染,将变量设置在局部域中,暴露出读写变量的方法。使之只能通过固定的接口读写变量,其他地方无法污染变量。这还有个好处就是不怕后面全局变量起重名,因为只取私有域中的变量,别处随意起名字不怕重名

2.让局部变量始终保存在内存中不被销毁。

上述例子中在addNum函数中设置了一个私有变量a,a和另一个函数用于a++并打印,调用了2次,分别打印出1和2。

首先函数中找变量是从最近的作用域开始找,如果找到变量则返回,找不到才会继续向外部作用域继续找,直到找到最外层的全局变量,还找不到的话则返回undefinded。所以即使局部域外面起了相同的变量名,因局部内找到此变量就返回了,可以防止全局变量污染局部变量;

后台的每个执行环境都有一个表示变量的对象——变量对象。全局环境的变量对象始终存在,而像 addNum()函数这样的局部环境的变量对象,则只在函数执行的过程中存在。一般来讲, 当函数执行完毕后,局部活动对象就会被销毁,内存中仅保存全局作用域(全局执行环境的变量对象)。 但是,闭包的情况又有所不同。

因为var plusNum=addNum()设置了全局变量plusNum,而plusNum中引用了变量a,函数在执行完毕后,其活动对象也不会被销毁,因为匿名函数的作用域链仍然在引用这个活动对象。

只有这个匿名函数被摧毁,这个活动对象才会被摧毁

plusNum()  //打印1
plusNum()  //打印2
plusNum=null; //清楚匿名函数
var plusNum=addNum();
plusNum()  //打印1
plusNum()  //打印2

 

 

 

 

你可能感兴趣的:(前端)