前端常见问题汇总(十一)_融合AI

一、技术基础

  1. 请简述-下JS 的事件循环机制,特别是微任务和宏任务的执行顺序。
    JavaScript 是单线程语言,通过事件循环机制实现异步操作。核心是协调调用栈、任务队列和微任务队列的执行。

核心概念

  1. 调用栈
    执行同步代码,后进先出(LIFO)
  2. 宏任务队列
    包括:setTimeout、setInterval、setImmediate(Node.js)、I/O、UI渲染
  3. 微任务队列
    包括:Promise.then/catch/finally、process.nextTick(Node.js)、MutationObserver、queueMicrotask

执行顺序

┌─────────────────────────────────────┐

│ 事件循环流程 │

├─────────────────────────────────────┤

│ 1. 执行同步代码(调用栈) │

│ ↓ │

│ 2. 调用栈清空后 │

│ ↓ │

│ 3. 执行所有微任务(清空微任务队列) │

│ ↓ │

│ 4. 执行一个宏任务 │

│ ↓ │

│ 5. UI渲染(浏览器) │

│ ↓ │

│ 返回步骤2(新一轮循环) │

└─────────────────────────────────────┘

关键规则:每次宏任务执行完后,会清空所有微任务,再执行下一个宏任务

复制代码
console.log('1. 同步代码');

setTimeout(() => {
  console.log('2. 宏任务 - setTimeout');
}, 0);

Promise.resolve().then(() => {
  console.log('3. 微任务 - Promise');
});

console.log('4. 同步代码结束');

// 执行结果:
// 1. 同步代码
// 4. 同步代码结束
// 3. 微任务 - Promise
// 2. 宏任务 - setTimeout

记忆口诀

同步先行,微任务次之,宏任务垫后

每个宏任务之间,清空所有微任务

相关推荐
ZhengEnCi5 分钟前
Q06-导航按钮高级拟态玻璃效果构建完全指南
前端·css
Apifox1 小时前
Apifox 6 月更新|Apifox CLI 全面升级、导入导出优化、OAuth 2.0 支持自动刷新令牌
前端·后端·测试
CodingSpace1 小时前
TypeScript 装饰器
前端
宸翰1 小时前
解决 uni-app App 端 vue-i18n 占位符丢失:封装跨端可用的 tf 格式化方法
前端·vue.js·uni-app
systemPro1 小时前
光储充系统数据流全解析:PV / ESS / GRID 数据怎么流转,线损怎么算
前端
古茗前端团队3 小时前
急招!前端|测试|后端|产品(名额多,速来)
前端·后端·架构
Lsx_4 小时前
不只是 Prompt:用 Superpowers Skill 给 AI 编程装上工程化工作流
前端·ai编程·claude
小碗细面4 小时前
前端 Prompt 工程实战:如何搭建场景化 Prompt 库
前端·ai编程
阿瑞IT4 小时前
2026年 AI Agent 生产化落地全景:四大高频故障根因分析与工程解法
前端
木木剑光4 小时前
我开源了一个 React 组件库,沉淀了多个高频组件和实用 Hooks
前端·javascript·react.js