为什么这个闭包示例工作不正确



我看过闭包的例子,我认为我理解它们,直到我决定这样做:

var f = [];
for (var i = 0; i < 2; i++) {
    f[i] = function foo(a) {
        var h = i;
        function bar() {
            console.log(h);
        }
        if (a == 1)
            bar();
    }
}
for (var j = 0; j < 2; j++) {
    console.log(f[j](1));
}

输出是这样的:

2
2

当我认为它将是0, 1时,因为我创建了一个外部函数foo,其中我将i存储在变量h中有人能解释一下这里发生了什么,以及为什么这些setTimeout的例子是正确的吗?

要获得所需的输出,请将代码更新为以下

var f = [];
for (var i = 0; i < 2; i++) {
  f[i] = (function(i){ 
              return function foo(a) {
                 var h = i;
                 function bar() {
                     console.log(h);
                 }
                 if (a == 1)
                    bar();
             }
         })(i);
}
for (var j = 0; j < 2; j++) {
    console.log(f[j](1));
}

最新更新