微任务和宏任务

在JavaScript中,任务分为两种类型:微任务和宏任务。

微任务是在当前任务执行完成后立即执行的任务,例如Promise回调、MutationObserver回调等。微任务的执行优先级高于宏任务。

宏任务是在当前任务执行完成后,等待一定时间后再执行的任务,例如setTimeout回调、setInterval回调、事件回调等。

在任务队列中,微任务排在宏任务之前执行。

例如以下代码:

复制代码
console.log("start");

setTimeout(() => {
  console.log("setTimeout");
}, 0);

Promise.resolve().then(() => {
  console.log("promise");
});

console.log("end");

输出的结果为:

复制代码
start
end
promise
setTimeout

原因是先执行同步代码输出start和end,然后遇到微任务,执行Promise回调输出promise,最后执行宏任务输出setTimeout。

相关推荐
灵感__idea1 天前
Hello 算法:“走一步看一步”的智慧
前端·javascript·算法
清水白石0081 天前
Python 编程实战全景:从基础语法到插件架构、异步性能与工程最佳实践
开发语言·python·架构
吴文周1 天前
告别重复劳动:一套插件让 AI 替你写代码、修Bug、做测试、上生产
前端·后端·ai编程
Mh1 天前
我决定写一个 3D 地球仪来记录下我要去的地方
前端·javascript·动效
yaoxin5211231 天前
390. Java IO API - WatchDir 示例
java·前端·python
懒狗小前端1 天前
做了一个 codex 的中文文档网站,做的不好可以随便喷
前端·后端
. . . . .1 天前
ref、useRef 和 forwardRef
前端·javascript·react.js
Halo_tjn1 天前
Java 基于字符串相关知识点
java·开发语言·算法
梦想的颜色1 天前
java 利用redis来限制用户频繁点击
java·开发语言
报错小能手1 天前
Swift 并发 Combine响应式框架
开发语言·ios·swift