闭包的简介:
闭包:就是能够读取其他函数内部变量的函数。只有函数内部的子函数才能读取局部变量,
实际理解为:闭包是函数内部和函数外部连接起来的桥梁。
当函数可以记住并访问所在词法作用域时,就产生了闭包,即使函数是在当前词法作用域之外执行。
闭包的定义:
如果在一个内部函数里,对在外部作用域(但不是全局作用域)的变量进行引用,那么内部函数就被认为是闭包。
闭包的特点:
- 可以读取自身函数外部的变量(沿着作用域链寻找)先从自身开始查找,如果自身没有才会继续往上级查找,自身如果拥有将直接调用。(离得最近的那个)
- 延长内部变量的生命周期
- 函数b嵌套在函数a内部
- 函数a返回函数b
闭包的作用:
在函数a执行完并返回后,闭包使得JavaScript的垃圾回收机制不会收回a所占用的资源,因为a的内部函数b的执行需要依赖a中的变量,闭包需要循序渐进的过程。
闭包的构成:
闭包有两个部分构成:
- 函数
- 创建函数的环境
应用场景:
- 保护函数内的变量安全。函数a中只有函数b才能访问,而无法通过其他途径访问到,因此保护了i的安全性。
- 在内存中维持一个变量
私有方法有利于限制对代码的访问,可以避免非核心的方法干扰代码的公共接口,减少全局污染。
闭包代码的小栗子:
var test = '全局test';
console.log(test);
function box() {
var test = '内部test';
function f() {
console.log(test);
return test;
}
console.log(test);
return f();
}
console.log(test);
box();
(扩展)回收机制:
在JavaScript中,如果一个对象不再被引用,那么这个对象就会被GC回收。如果俩个对象互相引用,而不再被第3者所引用,那么这俩个互相引用的对象也会被回收。因为函数a被b引用,b又被a外的c引用,这就是为什么函数a执行后不会被回收的原因
栗子:
var num = 6;
function box() {
var num = 1;
function box1() {
var n = 2;
alert(n + num);
}
return box1;
}
box()();
最后alert弹出框为3
注意点
由于闭包会使得函数中的变量都被保存在内存中,内存消耗很大,所以不能滥用闭包,否则会造成网页的性能问题,在IE中可能导致内存泄露。解决方法是,在退出函数之前,将不使用的局部变量全部删除。