closure!
总结一下闭包。
闭包的定义:当一个内部函数被其外部函数之外的变量所引用时,就形成了一个闭包。
一个最简单的闭包:
function A(){ var count=0; return function(){ count++; console.log(count); }; } var B=A(); B(); //1 B(); //2 B(); //3
important!=>javascript的GC机制:
在javascript中,如果一个对象不再被引用,那么这个对象就会被GC回收,否则这个对象一直会保存在内存中。
所以我们就可以理解为什么在上述代码中,A函数明明已经被返回退出执行了,变量count却没有被回收(count一直在原来的基础上增加1,而不是每一次都重新从0开始再增加1),因为匿名函数(闭包)被返回赋予变量B,即被变量B所引用(在javascript中对象的赋值是引用传递),故这个匿名函数不会GC回收,同时变量count被匿名函数所引用,所以变量count亦不会被回收,因此变量count才会一直会保存于内存中。
闭包的特性
js分全局作用域和函数作用域(没有块级作用域,if语句或for循环语句里面定义的变量在外部可以被访问)。函数作用域里可以访问到全局,通过一个叫作用域链(函数内部作用域=>父级函数的作用域=>父级函数的父级函数的作用域...=>全局作用域)的东西。
但全局怎么访问函数呢?我们可以通过在函数里面返回一个函数(闭包),就可以在全局访问到函数里的数据了(在上面代码中,我们在全局里访问到了A函数的count变量)。
不过闭包能访问到父级函数里面的数据说明父级函数里的数据一直存在内存中(一直被闭包所引用着),而没有被GC所回收,这就会导致内存一直被占着。