为什么呢?
for (var i = 0; i < 10; i++) {
setTimeout('console.log(i)',100);
}; //输出10
for (var i = 0; i < 10; i++) {
console.log(i)
}; //输出9
在看let和var的例子的时候,
var a = [];
for (var i = 0; i < 10; i++) {
a[i] = function () {
console.log(i);
};
console.log(i)
}//i到最后也是10.
第一个for循环,执行完毕的时候,i是10这个没异议吧,但是这个时候定时器里的函数还没执行,等100毫秒过去,打印的就是10个10,第二个for 循环,只有i小于10的时候才打印,所以打印的是0到9