var与let在for循环

Posted gggggggxin

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了var与let在for循环相关的知识,希望对你有一定的参考价值。

参考资料--阮一峰es6

var a = [];
for (var i = 0; i < 10; i++) {
  a[i] = function () {
    console.log(i);
  };
}
a[6](); // 10

上面代码中,变量i是var命令声明的,在全局范围内都有效,所以全局只有一个变量i。每一次循环,变量i的值都会发生改变,而循环内被赋给数组a的函数内部的console.log(i),里面的i指向的就是全局的i。也就是说,所有数组a的成员里面的i,指向的都是同一个i,导致运行时输出的是最后一轮的i的值,也就是 10。

如果使用let,声明的变量仅在块级作用域内有效,最后输出的是 6。

var a = [];
for (let i = 0; i < 10; i++) {
  a[i] = function () {
    console.log(i);
  };
}
a[6](); // 6

以上是关于var与let在for循环的主要内容,如果未能解决你的问题,请参考以下文章

let var 在for循环作用的具体解释

let var 在for循环作用的具体解释

let 命令 与 var的区别

小程序里let和var以及const区别

for循环中关于var和let的区别

let 跟 var的区别