⚡前端底层四连击:Event Loop → 渲染帧 → GC → AST,一篇打通任督二脉

1 Event Loop 执行顺序

  • 同步代码直接执行。
  • 遇到异步任务:
    -- setTimeoutsetIntervalsetImmediate 进入宏任务队列;
    -- Promise.thenqueueMicrotaskMutationObserver 进入微任务队列。
  • 每轮宏任务结束后,先清空微任务队列,再进入下一轮宏任务。
  • 微任务全部执行完后,浏览器进行一次渲染(重排/重绘)。

示例:

js 复制代码
console.log(1);
setTimeout(() => console.log(2), 0);
Promise.resolve().then(() => console.log(3));
console.log(4);
// 输出:1 4 3 2

2 浏览器渲染帧 16.67 ms 流程

  1. 样式计算:把 CSS 规则应用到 DOM 节点。
  2. 布局:计算每个节点的几何信息(位置、大小)。
  3. 绘制:把节点绘制成像素。
  4. 合成:把绘制结果合成到最终屏幕。

若总耗时 > 16.67 ms,页面掉帧。

优化:把动画放在 requestAnimationFrame,避免强制布局抖动。

3 垃圾回收

  • 新生代:对象存活时间短,使用 Scavenge 算法(复制存活对象)。
  • 老生代:对象存活时间长,使用 Mark-Sweep + Mark-Compact 算法(标记-清除-整理)。
  • 闭包泄漏 :函数返回后,其内部变量仍被外部引用,导致无法回收。
    解决:引用置空或使用 WeakMap/WeakRef

示例泄漏:

js 复制代码
function leak() {
  const big = new Array(1e6);
  return () => big.length; // big 被闭包引用
}
const f = leak(); // f 存在期间 big 无法回收

4 AST(抽象语法树)

  • 源代码 → 词法分析 → Tokens → 语法分析 → AST → 字节码 → 机器码。
  • 工具:
    -- esbuild :Go 实现,速度快。
    -- Babel :JavaScript 实现,转译新语法。
    -- Terser:基于 AST 压缩代码。

示例 AST 节点:

js 复制代码
// 源码:a + b
{
  type: 'BinaryExpression',
  operator: '+',
  left: { type: 'Identifier', name: 'a' },
  right: { type: 'Identifier', name: 'b' }
}

速查表

概念 关键点
Event Loop 宏任务→微任务→渲染
渲染帧 16.67 ms 内完成样式→布局→绘制→合成
垃圾回收 新生代复制、老生代标记整理;闭包引用置空
AST 源码→树→字节码→机器码,esbuild/Babel/Terser 基于它

背下这张表,面试不再慌张。

相关推荐
jin12332224 分钟前
React Native鸿蒙跨平台完成剧本杀组队详情页面,可以复用桌游、团建、赛事等各类组队详情页开发
javascript·react native·react.js·ecmascript·harmonyos
李白你好26 分钟前
Burp Suite插件用于自动检测Web应用程序中的未授权访问漏洞
前端
Abona1 小时前
C语言嵌入式全栈Demo
linux·c语言·面试
经年未远1 小时前
vue3中实现耳机和扬声器切换方案
javascript·学习·vue
刘一说1 小时前
Vue 组件不必要的重新渲染问题解析:为什么子组件总在“无故”刷新?
前端·javascript·vue.js
可触的未来,发芽的智生2 小时前
狂想:为AGI代称造字ta,《第三类智慧存在,神的赐名》
javascript·人工智能·python·神经网络·程序人生
徐同保2 小时前
React useRef 完全指南:在异步回调中访问最新的 props/state引言
前端·javascript·react.js
fanruitian2 小时前
uniapp 创建项目
javascript·vue.js·uni-app
刘一说3 小时前
Vue 导航守卫未生效问题解析:为什么路由守卫不执行或逻辑失效?
前端·javascript·vue.js
一周七喜h3 小时前
在Vue3和TypeScripts中使用pinia
前端·javascript·vue.js