for(var i=0;i<5;i++){
setTimeout(() => {
console.log(i)
}, 1000);
}
for(let i=0;i<5;i++){
setTimeout(() => {
console.log(i)
}, 1000);
}
首先 执行顺序是先执行完for循环,然后执行定时器。
使用var var变量会提升,每一次的赋值都是一次覆盖,当最后执行定时器时,定时器里所有的i值都会被覆盖,所以打印出来的都是同一个值。
使用let let会生成块级作用域,每一次生成的let i都是一个独立量 虽然重名 但是不会影响之前的let i,这样当执行定时器时,里面的i值都是独立的不会被影响也没有被覆盖,所以打印出来的值也不一样。
var i值的变化为 var i=0 i++ i++...这样。
let i值的变化为 let i =0(第一次, 执行i++后会变成 let i(这个i是新创建的)= i++(这个i是第一次创建的),这样其实每一个i都不一样,只是名字相同。
var 变量在作用域内会发生变量提升,当前层作用域内都是同一个变量,等到定时器执行时,值打印的就都是最后赋值的值。let 则每次创建一个新的变量。
您好,我是问答小助手,你的问题已经有小伙伴为您解答了问题,您看下是否解决了您的问题,可以追评进行沟通哦~
如果有您比较满意的答案 / 帮您提供解决思路的答案,可以点击【采纳】按钮,给回答的小伙伴一些鼓励哦~~
ps:问答VIP仅需29元,即可享受5次/月 有问必答服务,了解详情>>> https://vip.csdn.net/askvip?utm_source=1146287632
建议看一下阮一峰的es6的书,let 属于es6。https://es6.ruanyifeng.com/#docs/let