Plugin-webpack内置功能split-chunks-plugin配置打包代码分割

1.前言

split-chunks-plugin自动拆分公共代码三方依赖与异步模块从而:减少主包体积,提升页面加载速度,避免重复打包相同依赖。**Webpack 4+**内置的功能,无需额外安装或引入任何依赖。在vueCLI3+默认策略Vue CLI 2 需要手动添加。

没有代码分割时:所有node_modules打包进一个vendor.js,多个页面共用组件被重复打包,用户首次加载慢。

使用split-chunks-plugin:第三方库(如 Vue、Element UI) → chunk-vendors.js,多页面公共代码 → chunk-common.js,异步路由组件 → 按需加载的独立 chunk,利用浏览器缓存:业务代码更新不影响 vendor 缓存。

2.split-chunks-plugin配置

build/webpack.prod.conf.jsoptimization 中配置,Vue 2 + Webpack 4 项目

javascript 复制代码
module.exports = {
splitChunks: {
  // ┌──────────────────────────────────────┐
  // │ 基础策略                             │
  // └──────────────────────────────────────┘

  // 对哪些 chunk 进行拆分:
  // - 'initial':仅入口同步模块
  // - 'async':仅异步模块(如 import())
  // - 'all':两者都处理(推荐)
  chunks: 'all',

  // 模块体积 ≥20KB 才考虑拆分(单位:字节)
  // 太小的模块拆分会增加 HTTP 请求,得不偿失
  minSize: 20000,

  // 单个 chunk 最大不超过 244KB(可选)
  // 防止单个 vendor 包过大,利于 HTTP/1.1 并行加载或缓存
  maxSize: 244000,

  // 模块至少被引用 1 次就可被拆分
  // ⚠️ 关键!第三方库(如 vue、element-ui)通常只在 main.js 引入一次,
  //     若设为 2 会导致它们无法进入 vendor,仍留在主包中
  minChunks: 1,

  // 异步加载时,最大并行请求数(默认 30)
  // 控制按需加载的 chunk 数量,避免浏览器请求爆炸
  maxAsyncRequests: 30,

  // 首屏(初始加载)时,最大并行请求数
  // 包含:app.js + runtime.js + chunk-vendors.js + chunk-common.js 等
  // 设为 5 可安全容纳常见拆分结构(若设为 3 可能导致回退不拆分!)
  maxInitialRequests: 5,

  // 自动生成 chunk 名称时的分隔符
  // 例如:chunk-vendors~chunk-common.js
  automaticNameDelimiter: '~',

  // 是否自动生成有意义的 chunk 名称
  // true 表示根据模块路径和 cacheGroup 自动生成(推荐)
  name: true,


  // ┌──────────────────────────────────────┐
  // │ 缓存组(Cache Groups)               │
  // │ 优先级高的组先匹配,匹配后不再进入其他组 │
  // └──────────────────────────────────────┘

  cacheGroups: {
    // 【高优先级】拆分 node_modules(第三方依赖)
    vendor: {
      // 拆分后的 chunk 文件名
      name: 'chunk-vendors',

      // 匹配规则:所有来自 node_modules 的模块
      test: /[\\/]node_modules[\\/]/,

      // 优先级:数字越大越优先匹配
      // 必须高于 common(否则部分 node_modules 可能误入 common)
      priority: 10,

      // 仅对初始加载的模块生效(即非异步 import 的模块)
      // 避免把按需加载的第三方库(如路由内引入的 echarts)也打入 vendor
      chunks: 'initial',

      // 如果已有完全相同的模块 chunk,直接复用,不重复打包
      reuseExistingChunk: true,

      // 强制拆分:即使不满足 minSize/minChunks 也拆出
      // 确保 vendor chunk 一定生成(尤其当项目较小或依赖少时)
      enforce: true
    },

    // 【中优先级】拆分项目内部公共代码
    common: {
      // 拆分后的 chunk 文件名
      name: 'chunk-common',

      // 至少被 2 个 chunk 引用才拆分(适用于业务公共组件/工具函数)
      minChunks: 2,

      // 优先级低于 vendor
      priority: 5,

      // 同样只处理初始加载模块(可根据需要改为 'all')
      chunks: 'initial',

      // 复用已有 chunk
      reuseExistingChunk: true,

      // 强制拆分,确保公共代码独立
      enforce: true
    }

    // ⚠️ 不要添加 minChunks: Infinity 的组(如 commons),
    //    它永远不会命中,纯属冗余。
  }
},

// ┌──────────────────────────────────────┐
// │ 单独提取 Webpack 运行时代码           │
// │ 作用:使业务代码更新时不影响 runtime 缓存 │
// └──────────────────────────────────────┘
runtimeChunk: {
  name: 'runtime'
}
}
相关推荐
灵感__idea2 小时前
Hello 算法:贪心的世界
前端·javascript·算法
GreenTea3 小时前
一文搞懂Harness Engineering与Meta-Harness
前端·人工智能·后端
killerbasd5 小时前
牧苏苏传 我不装了 4/7
前端·javascript·vue.js
吴声子夜歌5 小时前
ES6——二进制数组详解
前端·ecmascript·es6
码事漫谈5 小时前
手把手带你部署本地模型,让你Token自由(小白专属)
前端·后端
ZC跨境爬虫6 小时前
【爬虫实战对比】Requests vs Scrapy 笔趣阁小说爬虫,从单线程到高效并发的全方位升级
前端·爬虫·scrapy·html
爱上好庆祝6 小时前
svg图片
前端·css·学习·html·css3
王夏奇6 小时前
python中的__all__ 具体用法
java·前端·python
大家的林语冰7 小时前
《前端周刊》尤大开源 Vite+ 全家桶,前端工业革命启动;尤大爆料 Void 云服务新产品,Vite 进军全栈开发;ECMA 源码映射规范......
前端·javascript·vue.js
jiayong237 小时前
第 8 课:开始引入组合式函数
前端·javascript·学习