闭包的作用
1.读取函数外部的变量(沿着作用域链寻找)
2.让外部变量始终保持在内存中
需要闭包的原因:由于js作用域链的原因导致外部很难获取函数的内部变量。
闭包的目的: 实现读取其他函数的内部变量,
function f1(){
var n=999;
function f2(){
alert(n);
}
return f2;
}
var result=f1();
result(); // 999
将函数绑定在全局变量上可以保证获取到的变量能到一直保持在内存中,实现复用
闭包的注意点
1)由于闭包会使得函数中的变量都被保存在内存中,内存消耗很大,所以不能滥用闭包,否则会造成网页的性能问题,在IE中可能导致内存泄露。解决方法是,在退出函数之前,将不使用的局部变量全部删除。
2)闭包会在父函数外部,改变父函数内部变量的值。所以,如果你把父函数当作对象(object)使用,把闭包当作它的公用方法(Public Method),把内部变量当作它的私有属性(private value),这时一定要小心,不要随便改变父函数内部变量的值。
深入理解闭包
var name = "The Window";
var object = {
name : "My Object",
getNameFunc : function(){
return function(){
return this.name;
};
}
};
alert(object.getNameFunc()());
输出为The window
var name = "The Window";
var object = {
name : "My Object",
getNameFunc : function(){
var that = this;
return function(){
return that.name;
};
}
};
alert(object.getNameFunc()());
输出为My object
闭包处翻译自阮一峰老师:http://www.ruanyifeng.com/blog/2009/08/learning_javascript_closures.html