147 字
1 分钟
浏览器JS运行原理

引言:以下JS代码运行的结果是什么?
function a() {
console.log("1");
Promise.resolve().then(() => {
console.log("2");
});
}
setTimeout(function () {
console.log("3");
Promise.resolve().then(a);
}, 0);
Promise.resolve().then(function () {
console.log("4");
});
console.log("5");
浏览器是如何按部就班执行命令的?
浏览器的所有操作都由渲染主线程执行,渲染主线程将创建一个无限循环的任务执行已有的任务,当渲染主线程无任务时将从消息队列中拿取新的任务执行。所有任务遵循先来后到,不允许插队执行
视频分析: