提起闭包,不得不提起js的特殊作用域
函数内部可以直接访问函数外部的变量,
但是函数外部不可以访问函数内部的值。
为了解决这个问题,提出了闭包。
js有特殊链式结构,虽然函数外部不可以访问函数内部的值,但如果我们在函数内嵌套一个函数呢,函数里的之对嵌套函数是完全可见的,此时利用嵌套函数访问函数值并返回,就可以拿到函数内部的值了。如图:
function f1(){
var num1 = 1;
function f2(){
console.log(num1);
}
return f2;
}
var fn = f1();
fn(); //1
事实上,f2就是闭包
闭包:能够读取其他函数内部变量的函数,只要函数没有释放,整条作用域链都会保留,函数内部和外部的桥梁。
闭包用途:
1.读取其他函数内部变量
2.保存变量值
在js中,局部变量在调用完成后会在调用结束时被垃圾回收机制回收
在闭包实现中,实际上把f2赋值给了一个全局变量fn,而全局变量不会在调用结束时被垃圾回收机制回收,而f1是f2的父函数,f2的实现与f1有关,所以f2整体作用域链都不会被回收。变量num1会一直保留值。
闭包缺点
1.内存泄漏
闭包让函数变量保存在内存中,消耗大量内存,如果滥用闭包,可能引起内存泄漏。在退出函数前要记得删除多余变量。
2.数据安全隐患
如果在父函数中,定义全局变量,并将可以改变父函数内部变量的匿名方法赋值给全局变量,那么在父函数外部也可以改变父函数里面的值,存在数据安全隐患。