1.闭包的概念及其应用
http://www.ruanyifeng.com/blog/2009/08/learning_javascript_closures.html
https://developer.mozilla.org/zh-CN/docs/Web/JavaScript/Closures
闭包就是能够读取其他函数内部变量的函数,有权访问另一个函数作用域中的变量的函数,创建闭包的常见方式,就是在一个函数内部创建另一个函数,通过另一个函数访问这个函数的局部变量。
由于在Javascript语言中,只有函数内部的子函数才能读取局部变量,因此可以把闭包简单理解成"定义在一个函数内部的函数"。
在本质上,闭包就是将函数内部和函数外部连接起来的一座桥梁
当函数a的内部函数b被a外的一个变量引用的时候就创建了一个闭包
(当函数x的内部函数y被x外的一个变量a引用的时候就创建了一个闭包)
eg: function x(){
var b=3;
function y(){
alert(b);
};
return y;
};
var a=x(); //执行x函数,返回子函数(y)
a(); //执行子函数(y)
必须提出一点的是作用域问题:
1.作用域的嵌套将形成作用域链,函数的嵌套将形成闭包。
2.作用域链在 JavaScript 中访问一个变量时,将从本地变量和参数开始,逐级向上遍历作用域直到全局作用域
3.闭包在一个函数中,定义另一个函数,称为函数嵌套。函数的嵌套将形成一个闭包。闭包与作用域链相辅相成,函数的嵌套在产生了链式关系的多个作用域的同时,也形成了一个闭包
函数闭包的注意点:
1)由于闭包会使得函数中的变量都被保存在内存中,内存消耗很大,所以不能滥用闭包,否则会造成网页的性能问题,在IE中可能导致内存泄露。解决方法是,在退出函数之前,将不使用的局部变量全部删除。
2)闭包会在父函数外部,改变父函数内部变量的值。所以,如果你把父函数当作对象(object)使用,把闭包当作它的公用方法(Public Method),把内部变量当作它的私有属性(private value),这时一定要小心,不要随便改变父函数内部变量的值。
双刃剑:
优点:可以把局部变量驻留在内存中,可以避免使用全局变量。
缺点:闭包会使得函数中的变量都被保存在内存中,内存消耗很大,会造成网页性能问题。