js---对事件循环宏任务和微任务的理解
JavaScript中的事件循环是基于宏任务和微任务的概念。宏任务,如:script(整体代码), setTimeout, setInterval, setImmediate(Node.js中), I/O, UI rendering。微任务,如:MutationObserver, process.nextTick(Node.js中), Promise.then, Object.observe(已废弃)等。
事件循环开始于宏任务,然后执行所有微任务。以下是一个示例代码,演示了这个过程:
console.log('script start');
setTimeout(function() {
console.log('setTimeout');
}, 0);
Promise.resolve().then(function() {
console.log('promise1');
}).then(function() {
console.log('promise2');
});
console.log('script end');
// 输出顺序为:
// script start
// script end
// promise1
// promise2
// setTimeout
在这个例子中,首先执行整个脚本作为第一个宏任务。然后,因为是异步代码,setTimeout和Promise.then注册了回调函数,但它们不会立即执行。
当执行完整个脚本后,JavaScript运行时会检查是否有已经被定义的微任务。在我们的例子中,有两个then方法注册的回调函数被执行,因此输出'promise1'和'promise2'。
最后,当微任务队列为空时,执行下一个宏任务,即setTimeout。
评论已关闭