这个插件为 Next.js 启用 Module Federation
强烈推荐参考这个应用,它充分利用了最佳功能: module-federation 示例
在底层,默认自动共享一些 Next 内部的内容 你不需要自己共享这些包,自行共享 Next 内部内容会引起错误。
在这个插件中,设置了 process.env.NEXT_PRIVATE_LOCAL_WEBPACK = 'true'
,但最好是在环境变量或命令行中设置。
"本地 Webpack" 意味着你必须将 webpack 安装为依赖项,并且 next 不会使用其捆绑的 webpack 副本,因为需要访问所有 webpack 内部
NEXT_PRIVATE_LOCAL_WEBPACK=true next dev
或 next build
npm install webpack
为了避免水合错误,使用 React.lazy
而不是 next/dynamic
来懒加载联合组件。
在页面级别安装异步边界后,可以执行以下操作:
你可以在这里看到它的实际应用:module-federation 示例
这个插件的工作方式与 ModuleFederationPlugin 完全相同,按正常方式使用即可。 请注意,我们已经自动为你共享了 react 和 next 相关的内容。
NextFederationPlugin 还有一个可选参数 extraOptions
,你可以用它来启用这个插件的额外功能:
debug
– 启用调试模式。它将打印关于底层发生情况的额外信息。exposePages
– 自动为你暴露所有的 Next.js 页面和它们的 ./pages-map
。enableImageLoaderFix
– 给所有由 nextjs-image-loader
打包的资产添加公共主机名。例如,如果你从 http://example.com
提供 remoteEntry,则所有打包资产将在运行时获取此主机名。这类似于 HTML 中的 Base URL,但用于联合模块。enableUrlLoaderFix
– 给所有由 url-loader
打包的资产添加公共主机名。skipSharingNextInternals
– 禁用共享 Next 内部。如果你想自己共享 Next 内部或在非 next 应用中使用此插件,则可以使用它。你可以在这里看到它的实际应用:module-federation 演示
next.config.js
中使用 NextFederationPlugin
。我们将这个应用称为 "next2"。要为 Module Federation 提供可扩展性和“中间件”,您可以参考 @module-federation/enhanced/runtime