JS闭包
JavaScript中的变量作用域:
在了解闭包前,首先要了解 JavaScript中的变量作用域 JavaScript的变量作用域有两种:全局变量和局部变量 在 JavaScript中函数内部可以读取全局变量,而函数外部不能读取函数内部的局部变量
怎样能在函数外部使用函数内部的局部变量呢?
通过闭包就能在函数外部使用函数内部的局部变量
代码如下:
function fun1(){
var a=1;
//fun2是一个闭包
function fun2(){
return ++a;
}
return fun2;
}
var f=fun1();
console.log(f());
在上述代码中 fun2是fun1的子函数,子函数可以调用父函数的内部变量,而父函数不能调用子函数的内部变量,
此时fun2可以调用fun1的内部变量,我们将fun2作为返回值,这样就可以在函数外部使用函数的内部变量了。
注意:这里不能将加号写在a后面,写在后面的话a++还没执行a就被返回了,返回的还是1。
运行结果:
闭包概念:
闭包是指有权访问另外一个函数作用域中的变量的函数
可以理解为 定义一个函数内部变量,将函数的内部变量在函数外部使用;
正常函数执行完毕后,里面声明的变量被垃圾回收处理掉,但是闭包可以让作用域里的变量,在函数执行完之后依旧保持没有被垃圾回收处理掉
闭包的作用:
* 可以读取函数内部的变量
* 让这些变量的值始终保持在内存中
闭包的注意事项:
* 由于闭包会使得函数中的变量都被保存在内存中,内存消耗很大,所以不能滥用闭包,否则会造成网页的性能问题,在IE中可能导致内存泄露。
* 闭包会在父函数外部改变父函数内部变量的值。所以,如果你把父函数当作对象(object)使用,把闭包当作它的公用方法(Public Method),把内部变量当作它的私有属性(private value),这时一定要小心,不要随便改变父函数内部变量的值。