js里的let和var区别

本文探讨了JavaScript中for循环与setTimeout的交互,解释了块级作用域下let与var声明变量的区别。当使用let时,每个setTimeout函数引用的是独立的变量实例,因此能正确输出循环中的每个值。而使用var时,所有setTimeout共享同一个变量,导致最后输出均为10。这揭示了JavaScript中的作用域和事件循环机制。
摘要由CSDN通过智能技术生成

1.转载https://www.cnblogs.com/fly_dragon/p/8669057.html
2.对于for循环+setTimeout的理解

//1块级作用域
// 对于let来说,分出了十块不同的作用域,里面的i值互不相通
// 和影响,执行玩定时器后再打印十个不同的i
for (let i = 0; i < 10; i++) { 
  setTimeout(function() {
    console.log(i);    //  i 是循环体内局部作用域,不受外界影响。
  }, 0);
}
// > 0
// > 1
// > 2
// > 3
// > 4
// > 5
// > 6
// > 7
// > 8
// > 9

// 对于var,十个i是相通的,一个变,个个变,而i=0的那时候的
// setTimeout的回调函数等到i=10之后才会执行(事件循环机制))
// 这时候所有的i都已经变成了10了,所以看到效果打印出来都是10
for (var i = 0; i < 10; i++) { 
  setTimeout(function() {
    console.log(i);    //  i 是循环体内局部作用域,不受外界影响。
  }, 0);
}

// > 10
// > 10
// > 10
// > 10
// > 10
// > 10
// > 10
// > 10
// > 10
// > 10




  • Var的时候,Settimeout本身是同步的, 但它里面的函数是异步的, for每次循环的时候settimeout也会执行 ,但是settimeout里面的函数不会执行, 会被放入到异步队列中 ,等道主任务for循环结束后,再从异步队列打印出东西
  • 使用 let 声明迭代变量时,JavaScript 引擎在后台会为每个迭代循环声明一个新的迭代变量。
    每个 setTimeout 引用的都是不同的变量实例,所以 console.log 输出的是我们期望的值,也就是循
    环执行过程中每个迭代变量的值。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值