for(var i=0;i<5;i++){
setTimeout(() => {
console.log(i)
}, 1000);
}
for(let i=0;i<5;i++){
setTimeout(() => {
console.log(i)
}, 1000);
}
为什么都是遍历,用var声明和let声明结果不一样?
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
4条回答 默认 最新
- Menkongkong 2021-03-27 10:28关注
首先 执行顺序是先执行完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都不一样,只是名字相同。
解决 3无用 1
悬赏问题
- ¥15 Vue3 大型图片数据拖动排序
- ¥15 划分vlan后不通了
- ¥15 GDI处理通道视频时总是带有白色锯齿
- ¥20 用雷电模拟器安装百达屋apk一直闪退
- ¥15 算能科技20240506咨询(拒绝大模型回答)
- ¥15 自适应 AR 模型 参数估计Matlab程序
- ¥100 角动量包络面如何用MATLAB绘制
- ¥15 merge函数占用内存过大
- ¥15 使用EMD去噪处理RML2016数据集时候的原理
- ¥15 神经网络预测均方误差很小 但是图像上看着差别太大