JS 函数的执行时机

JS 函数的执行时机

一个经典的面试题

let i=0
for(i=0;i<5;i++){
 setTimeout(()=>{
   console.log(i)
 
},0)
}

它的结果是6个6而不是0,1,2,3,4,5
是因为函数的调用时机不同
setTimeout函数是表示即刻去执行,但不代表当前就马上执行,这种情况就相当于,你打lol的时候,你妈喊你去吃饭,你当前却要把游戏打完,再去吃饭
把问题简化

let i=1;
function fn()
{
		setTimeout(()=>{
		  console.log(i)
		},0)
}
fn()
a=2

它的结果是2
而带了循环的代码也是一样,要把当前循环执行完了之后,才执行setTimeout里面的内容,

这相当于你设了6个闹钟,当然不会即可响

打印 0、1、2、3、4、5 的方法

for(let i=0;i<5;i++){
 setTimeout(()=>{
   console.log(i)
 
},0)
}

它的结果是0,1,2,3,4,5
为什么我把定义写在里面,就不一样了呢?
那是因为每一次循环都创建了一个i,每个i都不一样
(这是js为了迎合新人,做的设定)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值