今天看ES6的一篇文章里这样写:
var a = [];
for (let i = 0; i < 10; i++) {
a[i] = function () {
console.log(i);
};
}
a[6](); // 6
文档中说,上面代码中,变量i是let声明的,当前的i只在本轮循环有效,所以每一次循环的i其实都是一个新的变量,所以最后输出的是6。
但是a[6]不是function(){console.log(i)}吗?当运行a[6]()的时候,由于i是let声明的,只在块级作用域中有效,不应该是打印出undefined吗?怎么会是6呢?
for
每次循环生成一个新的作用域,fuction
内的i
访问的是这个作用域内的i
,大概可以像这样理解:可以将源代码使用 babel转义看看: