booleanfalse该选项用于 webpack 模块联邦(Module Federation)场景。
开启此选项后,Modern.js 会通过 dynamic import 来包裹自动生成的入口文件(Asynchronous Boundaries),使页面代码可以消费模块联邦生成的远程模块。
模块联邦(Module Federation,简称 MF)是一种让多个 JavaScript 应用可以共享代码和资源的技术方案。它类似于服务端的微服务架构,允许你将大型应用拆分成多个独立的小应用,这些小应用可以独立开发、测试和部署,同时还能在运行时动态加载其他应用的模块。
使用模块联邦可以解决多个前端应用之间代码重复的问题。传统方式下,如果多个应用需要使用相同的组件或工具函数,需要在每个应用中重复安装这些代码,导致代码重复、维护成本高、应用体积变大。使用模块联邦后,你可以将公共代码放在一个应用中,其他应用按需动态加载,实现代码共享,减少重复。
Module Federation 2.0 支持 Rspack 构建工具,并提供了动态类型提示、Manifest、Federation Runtime、运行时插件系统和 Chrome Devtools 等增强功能,提供更好的开发体验和调试能力。你可以访问 Module Federation 官方文档 了解更多信息。
Modern.js 提供了一个 Module Federation 的示例项目,请参考 module-federation-examples - modernjs。
首先,在配置文件中开启此选项:
export default defineConfig({
source: {
enableAsyncEntry: true,
},
});然后执行 dev 或 build 命令,可以看到 Modern.js 自动生成的文件变为以下结构:
node_modules
└─ .modern-js
└─ main
├─ bootstrap.jsx # 异步入口文件(asynchronous boundary)
├─ index.js # 真正的入口代码
└─ index.html其中 bootstrap.js 的内容如下:
import('./index.jsx');此时,就可以在当前页面中消费任意的远程模块了。
Modern.js 未对 ModuleFederationPlugin 进行封装,请通过 tools.bundlerChain 自行配置 ModuleFederationPlugin。