
深入理解 javascript 闭包
闭包在 javascript 中扮演着至关重要的角色,但对其的理解并不总是透彻。为了深入探讨闭包,请考虑以下代码段:
function fn() {
var num = 3;
return function() {
var n = 0;
n++;
num++;
console.log('n=' + n);
console.log('num=' + num);
}
}
var fn1 = fn();
fn1(); // 1 4
console.log("------");
fn1(); // 1 5问题:
- 为什么变量 n 每调用一次 fn1 都会重新初始化,而 num 却会累加?
答案:
当一个函数可以访问另一个函数内部变量时,就会形成闭包。在上述示例中,fn1 可以访问 fn 内部变量 num。
- n 是 fn1 的局部变量,每次调用都会重新创建。
- num 是 fn 的内部变量,在函数返回后不会被销毁。这是由于闭包的作用,fn1 仍可以访问 num。
因此,每次调用 fn1,n 都会被重新初始化,而 num 会基于之前的累积值继续累加。
需要注意的是,这种闭包的行为是 javascript 引擎的固有特性,以确保可以访问闭包中的变量。它不同于变量作用域,变量作用域仅在函数执行期间有效。










