一文搞懂 Webpack 分包:async、initial 与 all 的区别【附源码】

作者:程序员大卫日期:2025/11/28

大家好,我是前端架构师,关注微信公众号【程序员大卫】免费领取精品资料。

1. 背景

最近在优化一个项目的加载性能时,对 optimization.splitChunks.chunks 的三个可选值 asyncinitialall 的具体效果产生了疑惑。为了彻底搞清楚它们的区别,我专门搭建了一个 Demo 进行对比研究。

2. 核心区别:async vs initial

chunks 属性决定了 Webpack 对哪些类型的代码块进行分割。其中 async 是默认配置。

经过测试发现:在单入口应用中,二者区别不明显;但在多入口应用中,差异非常显著。

2.1 测试环境配置 (webpack.config.js)

为了直观观察分包结果,我将 minSize 设置为 0,确保即使是很小的模块也会被强制分割。

1const { CleanWebpackPlugin } = require("clean-webpack-plugin");
2
3module.exports = {
4  mode: "production",
5  entry: {
6    entry1: "./src/entry1.js",
7    entry2: "./src/entry2.js",
8  },
9  optimization: {
10    splitChunks: {
11      chunks: "async", // 实验变量:此处分别修改为 'async', 'initial', 'all'
12      minSize: 0       // 强制分割小模块
13    },
14  },
15  plugins: [
16    new CleanWebpackPlugin() // 每次构建前清理 dist 目录
17  ],
18};
19

2.2 代码结构

假设我们有两个入口文件,它们都引用了同步模块 shared.js,且 entry1 额外引用了一个异步模块 dynamic.js

  • entry1.js: 引用 shared + 动态引用 dynamic
  • entry2.js: 引用 shared
1// entry1.js
2import "./shared";       // 同步公共模块
3import("./dynamic");     // 异步动态导入
4console.log("entry1");
5
6// entry2.js
7import "./shared";       // 同步公共模块
8console.log("entry2");
9

2.3 打包结果对比

在上述场景下,切换配置会产生完全不同的结果:

  • 设置 chunks: 'async' (默认)
    • 结果dynamic.js 被单独打包,但 shared.js 没有被分离。
    • 原因async 只关注异步加载(动态导入)的模块。尽管 shared.js 被多个入口引用,但因为它是同步导入的,所以被忽略,直接打入了各自的入口包中。
  • 设置 chunks: 'initial'
    • 结果dynamic.js 被单独打包,同时 shared.js 也可以被剥离出来成为独立文件。
    • 原因initial 关注初始加载(同步导入)的模块。Webpack 发现 shared.js 在初始化时就被多个入口共享,因此将其分离。

3. 关于 all

当设置为 all 时,Webpack 会采用一种混合策略:无论同步还是异步,只要满足分割条件(如大小、引用次数),都会进行代码分割。

这是目前最推荐的配置,因为它能最大限度地复用代码,减小包体积。

4. 总结

三种模式的核心差异对比:

模式作用范围适用场景特点
async (默认)仅异步模块针对 import() 动态导入的模块确保首屏加载的 bundle 纯净,不影响初始包大小
initial仅同步模块针对入口文件直接 import 的公共模块优化多页应用的公共代码提取,减少重复打包
all所有模块希望最大化代码分割效果最全面的策略,通常能获得最佳的缓存利用率

源码地址: github.com/zm8/wechat-…


一文搞懂 Webpack 分包:async、initial 与 all 的区别【附源码】》 是转载文章,点击查看原文


相关推荐


别让页面 “鬼畜跳”!Google 钦点的 3 个性能指标,治好了我 80% 的用户投诉
PineappleCoder2025/12/9

💥告别卡顿!前端性能优化第一课:Google钦点的三大核心指标,你真的懂吗? 欢迎来到前端性能优化专栏的第一课!在这个“用户体验至上”的时代,一个卡顿、缓慢、乱跳的网站,就像一辆抛锚在高速公路上的跑车,再酷炫也只会让人抓狂。别担心,Google已经为你准备好了一份“体检报告”——核心Web指标(Core Web Vitals) 。 今天,我们就来揭开这份报告的神秘面纱,用最通俗易懂的方式,让你彻底搞懂这三大指标,迈出性能优化的第一步! ✨ LCP(Largest Contentful Pa


🚀你以为你在写 React?其实你在“搭一套前端操作系统”
白兰地空瓶2025/12/17

——从 Vite + React 架构出发,对照 Vue,彻底看懂现代前端工程化 👉 “现代前端不是写页面,而是在设计一套「运行在浏览器里的应用架构」。” 一、先说结论:React / Vue 早就不只是“框架”了 很多人学 React / Vue 的路径是这样的: JSX / template → 组件 → 状态 → 路由 → API 请求 ✋ 到此为止 但面试官想听的不是这个。 他们更关心的是: 你知不知道项目是怎么被“跑起来”的 dev / test / production


iOS开发必备的HTTP网络基础概览
sweet丶2025/12/25

一、从一次HTTP请求说起 以下是一个大体过程,不包含DNS缓存等等细节: sequenceDiagram participant C as 客户端(iOS App) participant D as DNS服务器 participant S as 目标服务器 participant T as TLS/SSL层 Note over C,S: 1. DNS解析阶段 C->>D: 查询域名对应IP D-->>C: 返回IP地址


深入UDP与sk_buff:掌握Linux网络协议栈的核心机制
咸鱼_要_翻身2026/1/3

目录 一、UDP 在网络协议栈中的位置 二、UDP 报文格式(RFC 768) 字段详解 三、UDP 如何解析报文?——定长头部分离机制 1、理解UDP报头 说明 注意事项 2、UDP数据封装流程:(自上而下) 3、UDP数据分用流程:(自下往上) 四、UDP 如何将数据交付给正确的应用进程?——端口分用(Demultiplexing) 工作流程 服务端 vs 客户端 五、UDP 的核心特性 1、无连接(Connectionless) 2、不可靠(Unrelia


从零构建 Vue 弹窗组件
yyt_2026/1/12

整体学习路线:简易弹窗 → 完善基础功能 → 组件内部状态管理 → 父→子传值 → 子→父传值 → 跨组件传值(最终目标) 步骤 1:搭建最基础的弹窗(静态结构,无交互) 目标:实现一个固定显示在页面中的弹窗,包含标题、内容、关闭按钮,掌握 Vue 组件的基本结构。 组件文件:BasicPopup.vue <template> <!-- 弹窗外层容器(遮罩层) --> <div class="popup-mask"> <!-- 弹窗主体 --> <div class="


万字长文!搞懂强化学习的基础知识!
aicoting2026/1/20

推荐直接网站在线阅读:aicoting.cn 强化学习是什么? 强化学习(Reinforcement Learning, RL)是一类通过与环境交互来学习最优决策策略的机器学习方法。与监督学习不同,强化学习没有直接提供的“正确答案”,而是通过奖励信号(reward)来评估行为的好坏。智能体(agent)在环境(environment)中执行动作(action),根据环境反馈获得奖励,并观察状态(state)变化。 强化学习的目标是学习一个策略,使得智能体在长期交互中获得累计奖励最大化。典型方法包


技术架构系列 - 详解Kafka
Prince-Peng2026/1/29

1. Kafka 知识脑图 2. Kafka 整体架构         首先,我们通过一张总览图来建立对Kafka生态系统的整体认知。这张图描绘了数据从生产到消费的完整路径,以及各核心组件之间的协作关系: 架构图解读: 数据流向:生产者(Producer)将消息推送(Push) 到Broker集群;消费者(Consumer)以拉取(Pull) 方式从Broker订阅消息。这种设计让消费者能根据自身处理能力控制速率,实现天然背压。核心角色: Broker:Kafka服务节点,


山野的风,城市的窗:一位拾粪爷爷与我的时代之问
修己xj2026/2/7

一、黑白影像中的昨日 今天在滑看手机时,一张九十年代的老照片忽然映入眼帘:一位穿着粗布衣裳的老人,背着一只粪筐,正弯着腰在路上拾粪。这一幕像一把沉默的钥匙,“咔哒”一声,轻轻旋开了我记忆的闸门——我又回到了童年那个黄土坡上的小村庄。 那时,村里也有这样一位爷爷。农闲时候,他总背着竹篾编的背篼,沿着村道慢慢走,看见驴粪、骡粪,便俯身拾起。如今想来,这样的画面在很多年轻人眼中,恐怕已陌生如传说。在那个年月,村里几乎家家都守着几亩田地,十有八九都养着头驴或骡子,犁地、驮货都靠它们。牲口走过,路上常留


超详细的云服务部署 OpenClaw 并接入飞书全流程,别再趟坑了
vortesnail2026/2/16

先讲点题外话 大概是 2015 年,我在大学寝室看了一部电影《她》,讲的是一个人与人工智能相爱的科幻爱情电影。 电影中的“女主”是斯嘉丽配音的人工智能操作系统 OS1 ,她可以深入了解、分析并理解你的生活,通过每日的经历不断成长和完善,不仅能够帮你实打实干事,还能够理解环境和用户的情绪,从而不断地进化成一个你越来越信任和依赖的伙伴。 那时候觉得这种形态的产品终究是会来的,想着 50 岁左右应该人工智能能发展到这种程度,但 2026 年的今天,已经能看到这种产品的雏形了!并且这回我坚定相信,今年


【HarmonyOS】day37:React Native实战项目+关键词高亮搜索Hook
星空22232026/2/24

【HarmonyOS】React Native实战项目+关键词高亮搜索Hook 📅 更新时间:2026年2月 🎯 技术栈:HarmonyOS NEXT + React Native 0.72.5 + TypeScript ⏱️ 阅读时间:约15分钟 前言 进入2026年,移动端开发格局已发生根本性变化。随着HarmonyOS NEXT彻底剥离AOSP,开发者面临着Android、iOS、HarmonyOS三足鼎立的局面。如何用一套代码高效覆盖三大平台? 本文将带你从零开

首页编辑器站点地图

本站内容在 CC BY-SA 4.0 协议下发布

Copyright © 2026 XYZ博客