Angular.json中的commonChunk 的作用

在Angular MFE项目中使用了自定义的webpack.config.js时,在结合Module_Federation中导出expose 设置为standalone:true的Component,然后host项目又使用了Module_Federation去引入导出的文件,向下面这样导入:

但是实际得到的结果是下面这样

但是预期结果应该是下面这样:

解决办法如下:

详解commonChunk

commonChunk 在 Angular 中的作用

commonChunk 是 Angular CLI 在构建过程中用于优化代码拆分的一个配置选项,主要用于提取多个入口文件或模块之间的公共依赖代码,生成独立的共享代码块(common chunk)。以下是其核心作用:

减少重复代码

通过将多个模块或组件共用的依赖(如第三方库、框架代码)提取到单独的 common.js 文件中,避免这些代码在多个生成的包中重复出现,从而减小整体打包体积。

提升缓存利用率

公共代码块独立后,浏览器可以缓存该文件,后续页面加载时直接复用缓存,减少网络请求和下载时间。尤其适用于多页应用或懒加载模块的场景。

优化加载性能

在懒加载模式下,用户访问不同路由时,公共依赖只需加载一次。后续路由切换时,仅需加载差异部分的代码,显著提升应用性能。

配置方式

在 Angular CLI 的早期版本(如 Angular 5+),可通过 angular.json 中的 optimization 配置项启用:

json 复制代码
{
  "projects": {
    "your-project": {
      "architect": {
        "build": {
          "options": {
            "optimization": {
              "commonChunk": true
            }
          }
        }
      }
    }
  }
}

注意事项

  • Angular 8+ 后,commonChunk 逐渐被更先进的打包策略(如 Webpack 4 的 SplitChunksPlugin)替代,配置方式可能有所不同。
  • 过度拆分可能导致过多小文件,需权衡缓存收益与 HTTP 请求开销。
  • 生产环境下默认启用优化,开发环境下通常关闭以加快构建速度。
相关推荐
网络与设备以及操作系统学习使用者12 分钟前
零信任架构落地实践详解
运维·网络·学习·架构
吃好睡好便好18 分钟前
说说眼睛的日常保健
学习·生活
_李小白24 分钟前
【android opencv学习笔记】Day 29: 滤波算法之Sobel 边缘检测
android·opencv·学习
丷丩24 分钟前
MapLibre GL JS第31课:添加实时数据
javascript·gis·map·mapbox·maplibre gl js
Engineer邓祥浩34 分钟前
宏观认知(3):AI战略与社会影响——吴恩达《AI for Everyone》Week3学习笔记
人工智能·笔记·学习
candyTong1 小时前
Claude Code 每次调用 API 时,上下文是怎么"拼"出来的?
javascript·后端·架构
千纸鹤の脉搏1 小时前
多线程的初步了解---进程与线程
java·开发语言·学习·线程
小林ixn1 小时前
别再背“变量提升”了!深入编译执行,彻底搞懂 JavaScript 运行机制
javascript
用户852495071841 小时前
为什么变量能 未定义先使用?
javascript·程序员
Larcher1 小时前
JS 变量提升:代码没动,为什么执行顺序就变了?
前端·javascript·前端框架