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
另,已找到实习,超开心,未来也要努力学习!!!