JS关于Promise和setTimeout的那些事儿

it2025-08-19  14

JS关于Promise和setTimeout的那些事儿

话不多说先上题:

new Promise(res=>{ setTimeout(()=>{console.log(000)},0) res() }).then(res=>{setTimeout(()=>{console.log(11111)},0)}) setTimeout(()=>{console.log(2222222)},0)

输出是这个样子:

前端面试里面,这个知识点是非常常考的。

具体跟事件循环,主线程,任务队列,宏任务,微任务有关。

Promise会放在微任务队列里面,属于异步任务。

同步任务执行完成以后,会先执行Promise函数。

再执行宏任务里面的setTimeout函数等。

但这个题比较复杂,Promise和setTimeout嵌套了,脑子好像无法思考了。

然后输出的这个918是干什么呢?918纪念日???

那我们把代码变得简单一点:

new Promise(res=>{ setTimeout(()=>{console.log(000)},0) res() }).then(console.log(11111)) setTimeout(()=>{console.log(2222222)},0)

new Promise(res=>{ console.log(0000); res() }).then(console.log(11111)) setTimeout(()=>{console.log(2222222)},0)

这样就清楚多了。

先挖个坑,前面具体原理日后来补。

保佑能找到工作!

加油!

发现一篇大佬的好文: https://blog.csdn.net/weixin_34050389/article/details/88679335

另,已找到实习,超开心,未来也要努力学习!!!

最新回复(0)