1.可以实现全局变量 的功能
//通过闭包可以实现局部变量的累加
function sum(){var age=21;
return function(){
age++;
return age;
}
}
var my_age=sum();
alert(my_age()); //21
alert(my_age()); //22
alert(my_age()); //23
由于闭包里作用返回的局部变量资源不会被回收,所以可能会用更 多的内存。过度使用闭包会性能下,建在非常有必要的时才使用闭包。
作用域链的机制导致一个问题,在循环中的匿名函数取得的任何变量都是最后一个值
//里包含名函数
functionbox() {
var arr =[];
for(vari=0;i<5;i++)
{
arr[i]=function()
{
return i;
};
}
return arr;
}
varb=box();
//得到函数数组 alert(b.length);
//得到函数集合长度 for(vari=0;i<b.length;i++) { alert(b[i]());
//输出个函数的值,都是最后一个值 }
上面的例子输出的结果都是 5,也就是后得到的最大的 i 值。因为 b[i]用的是 名函数,名函数并没有我执行,等到用的时,box()已执行完,i 已变成 5,所 以最的结果就是 5 个 5。
//循环里包含匿名函数-改 1,自我执行名函数
functionbox() {
vararr =[];
for(vari=0;i<5;i++){
arr[i]=(function(num) { //自我执行
return num;
})(i); //并且传参
}
return arr;
}
varb=box();
for(vari=0;i<b.length;i++) {
alert(b[i]); //这里返回的是数组,直接即可
}
改 1 中,我们让匿名函数进行自我执行,导致最终返回 a[i]的是数组而不是函数了。 最终导致 b[0]-b[4]中保留了 0,1,2,3,4 的值。
//循环里包含名函数-改 2,匿名函数下再做个匿名函数
functionbox() {
vararr =[];
for(vari=0;i<5;i++){
arr[i]=(function(num) {
return function(){ //直接返回值,改 2 变成返回函数
return num; //原理和改 1 一 样
}
})(i);
}
return arr;
}
varb=box();
for(vari=0;i<b.length;i++)
{
alert(b[i]()); //这里通过 b[i]()函数调用即可
}
改 1 和改 2 中,我们通过匿名函数自我执行,即把结果赋值给 a[i]。每一个 i,是 调用方法通过按值传递的,所以最终返回的都是指定的递增的 i。而不是 box()函数里的 i。
2.this对象,this对象在运行时基于函数的执行环境绑定的,而闭包在运行时是指向window的,因为闭包并不属于这个对象的属性或方法(用call(对象名)可以强制的要求指向那个对象)
3.内存泄漏 无法销毁驻留在内存中的元素,在使用完了之后要解除引用:obj=null;
ps:如果没有解除引用,那么需要等到浏览器关闭才得以释放
4.模仿块级作用域