setTimeout(function () {
console.log(1)
}, 0);
new Promise(function executor(resolve) {
resolve();
}).then(function () {
console.log(2);
});
如上代码,为什么运行结果是2,1而不是1,2?
不是setTimeout先加入任务队列吗?
setTimeout(function () {
console.log(1)
}, 0);
new Promise(function executor(resolve) {
resolve();
}).then(function () {
console.log(2);
});
如上代码,为什么运行结果是2,1而不是1,2?
不是setTimeout先加入任务队列吗?
3 回答1.5k 阅读
1 回答851 阅读✓ 已解决
1 回答1.1k 阅读
2 回答773 阅读
2 回答617 阅读
2 回答601 阅读
1 回答678 阅读
从规范上来讲,
setTimeout有一个4ms的最短时间,也就是说不管你设定多少,反正最少都要间隔4ms才运行里面的回调(当然,浏览器有没有遵守这个规范是另外一回事儿)。而Promise的异步没有这个问题。从具体实现上来说,这俩的异步队列不一样,
Promise所在的那个异步队列优先级要高一些。具体的你可以看这篇文章:从Promise来看JavaScript中的Event Loop、Tasks和Microtasks