面试官:npm run build 到底干了什么?从 package.json 到 dist 的 7 步拆解

本文以 Vite + Vue3 为例,逐行跟踪 npm run build 的全过程,附 1 张流程图 + 关键日志,看完能 30 秒答完面试。


一、总览:7 步流水线

text 复制代码
1. 读取 package.json → 2. 解析 build 脚本 → 3. Vite 打包 → 4. 代码分割 → 5. 压缩混淆 → 6. 生成 dist → 7. 输出报告

二、逐行拆解(以 Vite 为例)

① 读取 package.json

json 复制代码
"scripts": {
  "build": "vite build"
}

npm run build → 执行 vite build 命令。


② 解析 build 脚本

bash 复制代码
$ vite build

Vite CLI 被拉起,加载 vite.config.js 配置。


③ Vite 打包(Rollup 内核)

js 复制代码
// vite.config.js
export default defineConfig({
  plugins: [vue()],
  build: {
    rollupOptions: {
      output: {
        manualChunks: { vendor: ['vue'] } // 代码分割
      }
    }
  }
});
  1. 解析 入口 → 2. 分析 依赖 → 3. 生成 AST → 4. 转译 TS/JS → 5. Tree-Shaking 无用代码。

④ 代码分割

输出目录:

arduino 复制代码
dist/
├─ assets/
│  ├─ index.a1b2.js      // 业务代码
│  ├─ vendor.3c4d.js     // 第三方库
│  └─ index.e5f6.css     // 样式
└─ index.html            // 注入资源路径

⑤ 压缩混淆

  • Terser:压缩 JS(去掉空格、重命名变量)。
  • CSSO:压缩 CSS。
  • 图片压缩:webp/avif 转换。

⑥ 生成 dist

bash 复制代码
vite build
✓ 3 modules transformed.
dist/index.html              0.46 kB │ gzip: 0.29 kB
dist/assets/index.a1b2.js    45.21 kB │ gzip: 15.30 kB
dist/assets/vendor.3c4d.js   128.90 kB │ gzip: 45.20 kB

生成 哈希文件名,实现强缓存。


⑦ 输出报告

bash 复制代码
Build completed in 1.23s

可选开启 --report 查看包体积分析。


三、面试 30 秒回答模板

"npm run build 先读 package.json 找到 vite build,Vite 用 Rollup 打包:入口解析 → 依赖分析 → Tree-Shaking → 代码分割 → 压缩混淆 → 输出带哈希的 dist,整个过程 1-2 秒完成。"

相关推荐
你也向往长安城吗5 分钟前
推荐一个三维导航库:three-pathfinding-3d
javascript·算法
imLix6 分钟前
RunLoop 实现原理
前端·ios
wayman_he_何大民12 分钟前
初始机器学习算法 - 关联分析
前端·人工智能
karrigan14 分钟前
async/await 的优雅外衣下:Generator 的核心原理与 JavaScript 执行引擎的精细管理
javascript
飞飞飞仔16 分钟前
别再瞎写提示词了!这份Claude Code优化指南让你效率提升10倍
前端·claude
刘永胜是我16 分钟前
node版本切换
前端·node.js
成小白20 分钟前
前端实现表格下拉框筛选和表头回显和删除
前端
wayman_he_何大民21 分钟前
初始机器学习算法 - 聚类分析
前端·人工智能
wycode23 分钟前
Vue2实践(3)之用component做一个动态表单(二)
前端·javascript·vue.js
用户10922571561038 分钟前
你以为的 Tailwind 并不高效,看看这些使用误区
前端