let i = 0
for(i = 0; i<6; i++){
setTimeout(()=>{
console.log(i)
},0)
}
//[6,6,6,6,6,6]
以上代码会打印出6个6是因为变量i在for循环外部声明和定义,作用域在for以外。当for循环执行完了后,setTimeout函数才执行,而这时候i已经自增到了6,最后就打印6次6。
而以下代码会打印出0-5:
for(let i = 0; i<6; i++){
setTimeout(()=>{
console.log(i)
},0)
}
因为for在let的作用域中,不仅将i绑定到for循环中,同时将其重新绑定到循环体的每一次迭代中,确保上一次迭代结束的值重新被赋值。所以会打印出[0,1,2,3,4,5]。