为什么闭包中的变量 n 每次调用都会重新初始化,而 num 却会累加?

为什么闭包中的变量 n 每次调用都会重新初始化,而 num 却会累加?

深入理解 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 引擎的固有特性,以确保可以访问闭包中的变量。它不同于变量作用域,变量作用域仅在函数执行期间有效。

以上就是为什么闭包中的变量 n 每次调用都会重新初始化,而 num 却会累加?的详细内容,更多请关注其它相关文章!