JS代码中同时有Promise中的then与定时器两个异步函数时的执行顺序

举个例子

setTimeout(function() {
    console.log(1);
}, 0)
new Promise(function(resolve, reject) {
    console.log(2);
    resolve();
}).then(() => console.log(3))
console.log(4);

此段代码的执行结果为2 4 3 1
执行逻辑为:首先解析到定时器,因为是异步任务,所以添加到任务队列中,接下来实例化Promise,立即执行其中的内容,输出2,之后把then中的函数加入任务队列中,执行最后一行代码,输出4。此时任务队列中有两个任务,分别是setTimeout与then。then中的函数属于微任务,JS引擎内部的任务,所以先于setTimeout执行,输出3。最后执行setTimeou,它属于宏任务,浏览器API,输出1。
其实也没有太搞懂这个宏任务和微任务的区别,先记住,等以后学到了再说

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值