@modern-js/main-doc 2.69.4 → 3.0.0-alpha.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/docs/en/{_meta.json → _nav.json} +5 -1
- package/docs/en/apis/app/commands.mdx +2 -3
- package/docs/en/apis/app/hooks/src/entry.mdx +1 -5
- package/docs/en/apis/app/hooks/src/entry.server.mdx +4 -5
- package/docs/en/apis/app/hooks/src/routes.mdx +2 -2
- package/docs/en/apis/app/runtime/_meta.json +0 -18
- package/docs/en/apis/app/runtime/bff/use-hono-context.mdx +2 -2
- package/docs/en/apis/app/runtime/router/router.mdx +1 -1
- package/docs/en/apis/app/runtime/utility/css-in-js.mdx +3 -2
- package/docs/en/community/blog/v2-release-note.mdx +0 -2
- package/docs/en/community/contributing-guide.mdx +10 -12
- package/docs/en/components/bff-upload.mdx +16 -12
- package/docs/en/components/build-output.mdx +45 -0
- package/docs/en/components/debug-app.mdx +1 -1
- package/docs/en/components/enable-bff-caution.mdx +2 -2
- package/docs/en/components/enable-bff.mdx +38 -8
- package/docs/en/components/enable-ssg.mdx +48 -0
- package/docs/en/components/entry-scan-logic.mdx +7 -0
- package/docs/en/components/init-app.mdx +40 -17
- package/docs/en/components/international/install-command.mdx +9 -0
- package/docs/en/components/international/introduce.mdx +2 -0
- package/docs/en/components/module-federation.mdx +4 -4
- package/docs/en/components/new-entry-tooltip.mdx +0 -0
- package/docs/en/components/nodeVersion.mdx +2 -6
- package/docs/en/components/prerequisites.mdx +1 -1
- package/docs/en/components/ua-polyfill.mdx +16 -12
- package/docs/en/components/upgrade-browserslist.mdx +0 -0
- package/docs/en/configure/_meta.json +7 -8
- package/docs/en/configure/app/bff/cross-project.mdx +24 -0
- package/docs/en/configure/app/dev/lazy-compilation.mdx +45 -0
- package/docs/en/configure/app/dev/server.mdx +103 -0
- package/docs/en/configure/app/dev/setup-middlewares.mdx +4 -22
- package/docs/en/configure/app/html/app-icon.mdx +1 -23
- package/docs/en/configure/app/output/inline-scripts.mdx +1 -1
- package/docs/en/configure/app/output/override-browserslist.mdx +6 -4
- package/docs/en/configure/app/output/source-map.mdx +6 -3
- package/docs/en/configure/app/output/ssg.mdx +12 -43
- package/docs/en/configure/app/output/ssgByEntries.mdx +93 -0
- package/docs/en/configure/app/performance/build-cache.mdx +0 -4
- package/docs/en/configure/app/resolve/alias-strategy.mdx +14 -0
- package/docs/en/configure/app/resolve/alias.mdx +13 -0
- package/docs/en/configure/app/resolve/condition-names.mdx +18 -0
- package/docs/en/configure/app/resolve/dedupe.mdx +13 -0
- package/docs/en/configure/app/resolve/extensions.mdx +18 -0
- package/docs/en/configure/app/runtime/0-intro.mdx +2 -51
- package/docs/en/configure/app/security/check-syntax.mdx +1 -1
- package/docs/en/configure/app/server/port.mdx +1 -21
- package/docs/en/configure/app/server/rsc.mdx +30 -0
- package/docs/en/configure/app/server/ssr.mdx +20 -9
- package/docs/en/configure/app/source/decorators.mdx +4 -2
- package/docs/en/configure/app/source/entries.mdx +0 -2
- package/docs/en/configure/app/source/main-entry-name.mdx +4 -4
- package/docs/en/configure/app/source/transform-import.mdx +1 -59
- package/docs/en/configure/app/tools/bundler-chain.mdx +5 -5
- package/docs/en/configure/app/tools/css-extract.mdx +1 -1
- package/docs/en/configure/app/tools/dev-server.mdx +14 -248
- package/docs/en/configure/app/tools/html-plugin.mdx +3 -3
- package/docs/en/configure/app/tools/lightningcss-loader.mdx +0 -1
- package/docs/en/configure/app/tools/swc.mdx +1 -43
- package/docs/en/configure/app/usage.mdx +7 -17
- package/docs/en/guides/_meta.json +1 -2
- package/docs/en/guides/advanced-features/_meta.json +6 -0
- package/docs/en/guides/advanced-features/bff/cross-project.mdx +1 -7
- package/docs/en/guides/advanced-features/bff/extend-server.mdx +18 -3
- package/docs/en/guides/advanced-features/bff/frameworks.mdx +1 -1
- package/docs/en/guides/advanced-features/bff/function.mdx +2 -6
- package/docs/en/guides/advanced-features/bff/sdk.mdx +3 -3
- package/docs/en/guides/advanced-features/build-performance.mdx +23 -26
- package/docs/en/guides/advanced-features/compatibility.mdx +53 -9
- package/docs/en/guides/advanced-features/international/_meta.json +11 -0
- package/docs/en/guides/advanced-features/international/advanced.mdx +193 -0
- package/docs/en/guides/advanced-features/international/api.mdx +400 -0
- package/docs/en/guides/advanced-features/international/basic.mdx +417 -0
- package/docs/en/guides/advanced-features/international/best-practices.mdx +135 -0
- package/docs/en/guides/advanced-features/international/configuration.mdx +437 -0
- package/docs/en/guides/advanced-features/international/locale-detection.mdx +276 -0
- package/docs/en/guides/advanced-features/international/quick-start.mdx +154 -0
- package/docs/en/guides/advanced-features/international/resource-loading.mdx +417 -0
- package/docs/en/guides/advanced-features/international/routing.mdx +212 -0
- package/docs/en/guides/advanced-features/international.mdx +37 -0
- package/docs/en/guides/advanced-features/low-level.mdx +21 -16
- package/docs/en/guides/advanced-features/page-performance/code-split.mdx +4 -4
- package/docs/en/guides/advanced-features/page-performance/inline-assets.mdx +4 -4
- package/docs/en/guides/advanced-features/page-performance/optimize-bundle.mdx +7 -21
- package/docs/en/guides/advanced-features/page-performance/react-compiler.mdx +1 -8
- package/docs/en/guides/advanced-features/rspack-start.mdx +2 -22
- package/docs/en/guides/advanced-features/server-monitor/logger.mdx +0 -4
- package/docs/en/guides/advanced-features/server-monitor/monitors.mdx +62 -34
- package/docs/en/guides/advanced-features/web-server.mdx +82 -299
- package/docs/en/guides/basic-features/_meta.json +6 -1
- package/docs/en/guides/basic-features/css/css-in-js.mdx +46 -11
- package/docs/en/guides/basic-features/css/css-modules.mdx +5 -17
- package/docs/en/guides/basic-features/css/css.mdx +3 -3
- package/docs/en/guides/basic-features/css/tailwindcss.mdx +5 -89
- package/docs/en/guides/basic-features/data/data-cache.mdx +5 -1
- package/docs/en/guides/basic-features/data/data-fetch.mdx +4 -4
- package/docs/en/guides/basic-features/data/data-write.mdx +2 -2
- package/docs/en/guides/basic-features/debug/mock.mdx +4 -1
- package/docs/en/guides/basic-features/debug/proxy.mdx +0 -8
- package/docs/en/guides/basic-features/debug/rsdoctor.mdx +5 -5
- package/docs/en/guides/basic-features/deploy.mdx +25 -18
- package/docs/en/guides/basic-features/env-vars.mdx +1 -1
- package/docs/en/guides/basic-features/html.mdx +1 -1
- package/docs/en/guides/basic-features/output-files.mdx +3 -3
- package/docs/en/guides/basic-features/render/_meta.json +1 -1
- package/docs/en/guides/basic-features/render/before-render.mdx +16 -23
- package/docs/en/guides/basic-features/render/overview.mdx +51 -0
- package/docs/en/guides/basic-features/render/rsc.mdx +394 -0
- package/docs/en/guides/basic-features/render/ssg.mdx +26 -62
- package/docs/en/guides/basic-features/render/ssr-cache.mdx +6 -6
- package/docs/en/guides/basic-features/render/ssr.mdx +31 -31
- package/docs/en/guides/basic-features/render/streaming-ssr.mdx +29 -9
- package/docs/en/guides/basic-features/routes/_meta.json +1 -0
- package/docs/en/guides/basic-features/routes/config-routes.mdx +427 -0
- package/docs/en/guides/basic-features/{routes.mdx → routes/routes.mdx} +7 -110
- package/docs/en/guides/basic-features/static-assets/json-files.mdx +21 -3
- package/docs/en/guides/basic-features/static-assets.mdx +2 -2
- package/docs/en/guides/concept/builder.mdx +24 -9
- package/docs/en/guides/concept/entries.mdx +139 -147
- package/docs/en/guides/get-started/glossary.mdx +0 -18
- package/docs/en/guides/get-started/introduction.mdx +1 -4
- package/docs/en/guides/get-started/quick-start.mdx +8 -73
- package/docs/en/guides/get-started/tech-stack.mdx +7 -25
- package/docs/en/guides/get-started/upgrade.mdx +30 -23
- package/docs/en/guides/topic-detail/_meta.json +0 -12
- package/docs/en/guides/topic-detail/module-federation/_meta.json +1 -1
- package/docs/en/guides/topic-detail/module-federation/application.mdx +16 -15
- package/docs/en/guides/topic-detail/module-federation/i18n.mdx +670 -0
- package/docs/en/guides/topic-detail/module-federation/introduce.mdx +5 -4
- package/docs/en/guides/topic-detail/module-federation/ssr.mdx +50 -2
- package/docs/en/guides/topic-detail/module-federation/usage.mdx +10 -30
- package/docs/en/guides/troubleshooting/builder.mdx +3 -82
- package/docs/en/guides/troubleshooting/cli.mdx +6 -30
- package/docs/en/guides/troubleshooting/dependencies.mdx +22 -22
- package/docs/en/plugin/cli-plugins/api.mdx +4 -5
- package/docs/en/plugin/cli-plugins/migration.mdx +33 -48
- package/docs/en/plugin/introduction.mdx +39 -27
- package/docs/en/plugin/official/_meta.json +0 -5
- package/docs/en/plugin/official/cli-plugins/_meta.json +1 -1
- package/docs/en/plugin/official/cli-plugins/plugin-styled-components.mdx +5 -0
- package/docs/en/plugin/official/cli-plugins.mdx +0 -2
- package/docs/en/plugin/plugin-system.mdx +68 -61
- package/docs/en/plugin/runtime-plugins/api.mdx +62 -59
- package/docs/en/plugin/runtime-plugins/migration.mdx +29 -20
- package/docs/en/tutorials/_meta.json +0 -10
- package/docs/en/tutorials/examples/csr-auth.mdx +1 -1
- package/docs/en/tutorials/foundations/introduction.mdx +9 -25
- package/docs/zh/{_meta.json → _nav.json} +10 -6
- package/docs/zh/apis/app/commands.mdx +2 -3
- package/docs/zh/apis/app/hooks/src/entry.mdx +1 -5
- package/docs/zh/apis/app/hooks/src/entry.server.mdx +4 -5
- package/docs/zh/apis/app/hooks/src/routes.mdx +2 -2
- package/docs/zh/apis/app/runtime/_meta.json +0 -18
- package/docs/zh/apis/app/runtime/bff/use-hono-context.mdx +2 -2
- package/docs/zh/apis/app/runtime/utility/css-in-js.mdx +3 -2
- package/docs/zh/community/blog/v2-release-note.mdx +0 -2
- package/docs/zh/community/contributing-guide.mdx +10 -12
- package/docs/zh/components/auto-upgrade.mdx +0 -0
- package/docs/zh/components/bff-upload.mdx +8 -5
- package/docs/zh/components/build-output.mdx +45 -0
- package/docs/zh/components/debug-app.mdx +1 -1
- package/docs/zh/components/enable-bff-caution.mdx +1 -1
- package/docs/zh/components/enable-bff.mdx +37 -8
- package/docs/zh/components/enable-ssg.mdx +47 -0
- package/docs/zh/components/entry-scan-logic.mdx +7 -0
- package/docs/zh/components/init-app.mdx +40 -18
- package/docs/zh/components/international/install-command.mdx +8 -0
- package/docs/zh/components/international/introduce.mdx +2 -0
- package/docs/zh/components/international/platform-support.mdx +0 -0
- package/docs/zh/components/module-federation.mdx +4 -4
- package/docs/zh/components/new-entry-tooltip.mdx +0 -0
- package/docs/zh/components/nodeVersion.mdx +3 -7
- package/docs/zh/components/prerequisites.mdx +1 -1
- package/docs/zh/components/self-route-example.mdx +3 -3
- package/docs/zh/components/ua-polyfill.mdx +11 -6
- package/docs/zh/components/upgrade-browserslist.mdx +0 -0
- package/docs/zh/configure/_meta.json +7 -8
- package/docs/zh/configure/app/bff/cross-project.mdx +24 -0
- package/docs/zh/configure/app/dev/lazy-compilation.mdx +44 -0
- package/docs/zh/configure/app/dev/server.mdx +104 -0
- package/docs/zh/configure/app/dev/setup-middlewares.mdx +4 -23
- package/docs/zh/configure/app/html/app-icon.mdx +1 -23
- package/docs/zh/configure/app/output/inline-scripts.mdx +1 -1
- package/docs/zh/configure/app/output/override-browserslist.mdx +3 -3
- package/docs/zh/configure/app/output/source-map.mdx +10 -3
- package/docs/zh/configure/app/output/ssg.mdx +13 -45
- package/docs/zh/configure/app/output/ssgByEntries.mdx +94 -0
- package/docs/zh/configure/app/performance/build-cache.mdx +0 -4
- package/docs/zh/configure/app/resolve/alias-strategy.mdx +14 -0
- package/docs/zh/configure/app/resolve/alias.mdx +13 -0
- package/docs/zh/configure/app/resolve/condition-names.mdx +18 -0
- package/docs/zh/configure/app/resolve/dedupe.mdx +14 -0
- package/docs/zh/configure/app/resolve/extensions.mdx +18 -0
- package/docs/zh/configure/app/runtime/0-intro.mdx +2 -53
- package/docs/zh/configure/app/security/check-syntax.mdx +1 -1
- package/docs/zh/configure/app/server/port.mdx +2 -21
- package/docs/zh/configure/app/server/rsc.mdx +30 -0
- package/docs/zh/configure/app/server/ssr.mdx +21 -11
- package/docs/zh/configure/app/source/decorators.mdx +4 -4
- package/docs/zh/configure/app/source/entries.mdx +0 -2
- package/docs/zh/configure/app/source/main-entry-name.mdx +4 -4
- package/docs/zh/configure/app/source/transform-import.mdx +1 -59
- package/docs/zh/configure/app/tools/bundler-chain.mdx +6 -6
- package/docs/zh/configure/app/tools/css-extract.mdx +1 -1
- package/docs/zh/configure/app/tools/dev-server.mdx +14 -248
- package/docs/zh/configure/app/tools/html-plugin.mdx +3 -2
- package/docs/zh/configure/app/tools/lightningcss-loader.mdx +0 -1
- package/docs/zh/configure/app/tools/swc.mdx +1 -43
- package/docs/zh/configure/app/usage.mdx +8 -18
- package/docs/zh/guides/_meta.json +5 -1
- package/docs/zh/guides/advanced-features/_meta.json +6 -1
- package/docs/zh/guides/advanced-features/bff/cross-project.mdx +8 -16
- package/docs/zh/guides/advanced-features/bff/extend-server.mdx +25 -8
- package/docs/zh/guides/advanced-features/bff/frameworks.mdx +1 -1
- package/docs/zh/guides/advanced-features/bff/function.mdx +7 -12
- package/docs/zh/guides/advanced-features/bff/sdk.mdx +4 -4
- package/docs/zh/guides/advanced-features/build-performance.mdx +23 -30
- package/docs/zh/guides/advanced-features/compatibility.mdx +44 -0
- package/docs/zh/guides/advanced-features/international/_meta.json +11 -0
- package/docs/zh/guides/advanced-features/international/advanced.mdx +193 -0
- package/docs/zh/guides/advanced-features/international/api.mdx +400 -0
- package/docs/zh/guides/advanced-features/international/basic.mdx +416 -0
- package/docs/zh/guides/advanced-features/international/best-practices.mdx +135 -0
- package/docs/zh/guides/advanced-features/international/configuration.mdx +441 -0
- package/docs/zh/guides/advanced-features/international/locale-detection.mdx +304 -0
- package/docs/zh/guides/advanced-features/international/quick-start.mdx +149 -0
- package/docs/zh/guides/advanced-features/international/resource-loading.mdx +417 -0
- package/docs/zh/guides/advanced-features/international/routing.mdx +212 -0
- package/docs/zh/guides/advanced-features/international.mdx +36 -0
- package/docs/zh/guides/advanced-features/low-level.mdx +21 -16
- package/docs/zh/guides/advanced-features/page-performance/code-split.mdx +3 -3
- package/docs/zh/guides/advanced-features/page-performance/inline-assets.mdx +4 -4
- package/docs/zh/guides/advanced-features/page-performance/optimize-bundle.mdx +7 -21
- package/docs/zh/guides/advanced-features/page-performance/react-compiler.mdx +1 -8
- package/docs/zh/guides/advanced-features/server-monitor/logger.mdx +0 -4
- package/docs/zh/guides/advanced-features/server-monitor/monitors.mdx +63 -35
- package/docs/zh/guides/advanced-features/web-server.mdx +79 -300
- package/docs/zh/guides/basic-features/_meta.json +6 -1
- package/docs/zh/guides/basic-features/css/css-in-js.mdx +40 -5
- package/docs/zh/guides/basic-features/css/css-modules.mdx +6 -17
- package/docs/zh/guides/basic-features/css/css.mdx +2 -2
- package/docs/zh/guides/basic-features/css/tailwindcss.mdx +6 -90
- package/docs/zh/guides/basic-features/data/data-cache.mdx +8 -5
- package/docs/zh/guides/basic-features/data/data-fetch.mdx +6 -5
- package/docs/zh/guides/basic-features/data/data-write.mdx +4 -4
- package/docs/zh/guides/basic-features/debug/mock.mdx +4 -1
- package/docs/zh/guides/basic-features/debug/proxy.mdx +0 -8
- package/docs/zh/guides/basic-features/debug/rsdoctor.mdx +6 -6
- package/docs/zh/guides/basic-features/deploy.mdx +24 -20
- package/docs/zh/guides/basic-features/env-vars.mdx +1 -1
- package/docs/zh/guides/basic-features/html.mdx +2 -2
- package/docs/zh/guides/basic-features/output-files.mdx +3 -3
- package/docs/zh/guides/basic-features/render/_meta.json +1 -1
- package/docs/zh/guides/basic-features/render/before-render.mdx +17 -24
- package/docs/zh/guides/basic-features/render/overview.mdx +52 -0
- package/docs/zh/guides/basic-features/render/rsc.mdx +413 -0
- package/docs/zh/guides/basic-features/render/ssg.mdx +27 -69
- package/docs/zh/guides/basic-features/render/ssr-cache.mdx +5 -5
- package/docs/zh/guides/basic-features/render/ssr.mdx +34 -31
- package/docs/zh/guides/basic-features/render/streaming-ssr.mdx +34 -14
- package/docs/zh/guides/basic-features/routes/_meta.json +1 -0
- package/docs/zh/guides/basic-features/routes/config-routes.mdx +426 -0
- package/docs/zh/guides/basic-features/{routes.mdx → routes/routes.mdx} +8 -114
- package/docs/zh/guides/basic-features/static-assets/json-files.mdx +21 -3
- package/docs/zh/guides/basic-features/static-assets.mdx +2 -2
- package/docs/zh/guides/basic-features/testing/cypress.mdx +5 -5
- package/docs/zh/guides/basic-features/testing/jest.mdx +12 -12
- package/docs/zh/guides/concept/builder.mdx +24 -9
- package/docs/zh/guides/concept/entries.mdx +95 -92
- package/docs/zh/guides/get-started/glossary.mdx +0 -18
- package/docs/zh/guides/get-started/introduction.mdx +1 -5
- package/docs/zh/guides/get-started/quick-start.mdx +5 -72
- package/docs/zh/guides/get-started/tech-stack.mdx +8 -26
- package/docs/zh/guides/get-started/upgrade.mdx +30 -23
- package/docs/zh/guides/topic-detail/_meta.json +0 -12
- package/docs/zh/guides/topic-detail/module-federation/_meta.json +1 -1
- package/docs/zh/guides/topic-detail/module-federation/application.mdx +18 -16
- package/docs/zh/guides/topic-detail/module-federation/i18n.mdx +623 -0
- package/docs/zh/guides/topic-detail/module-federation/introduce.mdx +4 -4
- package/docs/zh/guides/topic-detail/module-federation/ssr.mdx +51 -5
- package/docs/zh/guides/topic-detail/module-federation/usage.mdx +11 -32
- package/docs/zh/guides/troubleshooting/builder.mdx +3 -84
- package/docs/zh/guides/troubleshooting/cli.mdx +6 -30
- package/docs/zh/guides/troubleshooting/dependencies.mdx +23 -23
- package/docs/zh/guides/upgrade/_meta.json +1 -0
- package/docs/zh/guides/upgrade/config.mdx +809 -0
- package/docs/zh/guides/upgrade/entry.mdx +463 -0
- package/docs/zh/guides/upgrade/other.md +90 -0
- package/docs/zh/guides/upgrade/overview.mdx +36 -0
- package/docs/zh/guides/upgrade/tailwindcss.mdx +130 -0
- package/docs/zh/guides/upgrade/web-server.md +93 -0
- package/docs/zh/plugin/cli-plugins/api.mdx +4 -5
- package/docs/zh/plugin/cli-plugins/migration.mdx +30 -45
- package/docs/zh/plugin/introduction.mdx +36 -24
- package/docs/zh/plugin/official/_meta.json +0 -5
- package/docs/zh/plugin/official/cli-plugins/_meta.json +1 -1
- package/docs/zh/plugin/official/cli-plugins/plugin-styled-components.mdx +5 -0
- package/docs/zh/plugin/official/cli-plugins.mdx +0 -2
- package/docs/zh/plugin/plugin-system.mdx +45 -42
- package/docs/zh/plugin/runtime-plugins/api.mdx +58 -56
- package/docs/zh/plugin/runtime-plugins/migration.mdx +26 -17
- package/docs/zh/tutorials/_meta.json +0 -10
- package/docs/zh/tutorials/examples/csr-auth.mdx +1 -1
- package/docs/zh/tutorials/foundations/introduction.mdx +8 -25
- package/i18n.json +0 -16
- package/package.json +12 -12
- package/rspress.config.ts +5 -8
- package/src/components/ContentCard/index.module.scss +11 -7
- package/src/components/ContentCard/index.tsx +1 -1
- package/src/components/FeatureLayout/index.module.css +1 -1
- package/src/components/Footer/index.tsx +2 -14
- package/src/components/Footer/styles.module.scss +5 -5
- package/src/components/ListCard/index.tsx +1 -1
- package/src/components/RandomMemberList/index.tsx +1 -1
- package/src/components/RsbuildLink/index.tsx +1 -1
- package/src/components/Sandpack/index.tsx +1 -1
- package/src/custom.scss +15 -0
- package/src/i18n/enUS.ts +2 -4
- package/src/i18n/index.ts +1 -1
- package/src/i18n/zhCN.ts +2 -4
- package/src/index.ts +2 -1
- package/src/pages/index.module.scss +59 -41
- package/src/pages/index.tsx +9 -24
- package/docs/en/apis/app/hooks/server/index_.mdx +0 -10
- package/docs/en/apis/app/hooks/src/index_.mdx +0 -38
- package/docs/en/apis/app/hooks/src/stories.mdx +0 -16
- package/docs/en/apis/app/runtime/app/define-config.mdx +0 -67
- package/docs/en/apis/app/runtime/core/bootstrap.mdx +0 -74
- package/docs/en/apis/app/runtime/core/create-app.mdx +0 -49
- package/docs/en/apis/app/runtime/core/use-loader.mdx +0 -89
- package/docs/en/apis/app/runtime/core/use-module-apps.mdx +0 -140
- package/docs/en/apis/app/runtime/core/use-runtime-context.mdx +0 -116
- package/docs/en/apis/app/runtime/model/Provider.mdx +0 -36
- package/docs/en/apis/app/runtime/model/auto-actions.mdx +0 -122
- package/docs/en/apis/app/runtime/model/connect.mdx +0 -146
- package/docs/en/apis/app/runtime/model/create-app.mdx +0 -75
- package/docs/en/apis/app/runtime/model/create-store.mdx +0 -61
- package/docs/en/apis/app/runtime/model/handle-effect.mdx +0 -107
- package/docs/en/apis/app/runtime/model/model_.mdx +0 -198
- package/docs/en/apis/app/runtime/model/use-local-model.mdx +0 -29
- package/docs/en/apis/app/runtime/model/use-model.mdx +0 -89
- package/docs/en/apis/app/runtime/model/use-static-model.mdx +0 -51
- package/docs/en/apis/app/runtime/model/use-store.mdx +0 -26
- package/docs/en/apis/app/runtime/ssr/pre-render.mdx +0 -96
- package/docs/en/apis/app/runtime/web-server/hook.mdx +0 -134
- package/docs/en/apis/app/runtime/web-server/middleware.mdx +0 -113
- package/docs/en/apis/app/runtime/web-server/unstable_middleware.mdx +0 -167
- package/docs/en/components/bff-proxy-path-rewrite.mdx +0 -16
- package/docs/en/components/bff-proxy-principle.mdx +0 -1
- package/docs/en/components/builder.mdx +0 -3
- package/docs/en/components/create-bff-api-app.mdx +0 -25
- package/docs/en/components/custom-router-micro-frontend.mdx +0 -40
- package/docs/en/components/enable-micro-frontend.mdx +0 -30
- package/docs/en/components/enableSwc.mdx +0 -17
- package/docs/en/components/global-proxy-config.mdx +0 -85
- package/docs/en/components/global-proxy.mdx +0 -29
- package/docs/en/components/package-manager.mdx +0 -11
- package/docs/en/components/reduck-notify.mdx +0 -27
- package/docs/en/components/reduck-tip.mdx +0 -8
- package/docs/en/configure/app/auto-load-plugin.mdx +0 -66
- package/docs/en/configure/app/deploy/microFrontend.mdx +0 -53
- package/docs/en/configure/app/dev/port.mdx +0 -25
- package/docs/en/configure/app/dev/proxy.mdx +0 -9
- package/docs/en/configure/app/experiments/lazy-compilation.mdx +0 -106
- package/docs/en/configure/app/html/disable-html-folder.mdx +0 -46
- package/docs/en/configure/app/html/favicon-by-entries.mdx +0 -36
- package/docs/en/configure/app/html/inject-by-entries.mdx +0 -36
- package/docs/en/configure/app/html/meta-by-entries.mdx +0 -48
- package/docs/en/configure/app/html/tags-by-entries.mdx +0 -44
- package/docs/en/configure/app/html/template-by-entries.mdx +0 -33
- package/docs/en/configure/app/html/template-parameters-by-entries.mdx +0 -35
- package/docs/en/configure/app/html/title-by-entries.mdx +0 -37
- package/docs/en/configure/app/output/css-module-local-ident-name.mdx +0 -21
- package/docs/en/configure/app/output/disable-css-extract.mdx +0 -16
- package/docs/en/configure/app/output/disable-filename-hash.mdx +0 -16
- package/docs/en/configure/app/output/disable-minimize.mdx +0 -14
- package/docs/en/configure/app/output/disable-node-polyfill.mdx +0 -22
- package/docs/en/configure/app/output/disable-source-map.mdx +0 -31
- package/docs/en/configure/app/output/enable-asset-fallback.mdx +0 -36
- package/docs/en/configure/app/output/enable-inline-scripts.mdx +0 -22
- package/docs/en/configure/app/output/enable-inline-styles.mdx +0 -22
- package/docs/en/configure/app/output/enable-latest-decorators.mdx +0 -14
- package/docs/en/configure/app/performance/transform-lodash.mdx +0 -52
- package/docs/en/configure/app/runtime/master-app.mdx +0 -36
- package/docs/en/configure/app/runtime/state.mdx +0 -52
- package/docs/en/configure/app/source/disable-entry-dirs.mdx +0 -38
- package/docs/en/configure/app/source/enable-custom-entry.mdx +0 -68
- package/docs/en/configure/app/source/module-scopes.mdx +0 -72
- package/docs/en/configure/app/source/resolve-extension-prefix.mdx +0 -55
- package/docs/en/configure/app/source/resolve-main-fields.mdx +0 -46
- package/docs/en/configure/app/tools/esbuild.mdx +0 -44
- package/docs/en/configure/app/tools/pug.mdx +0 -54
- package/docs/en/configure/app/tools/styled-components.mdx +0 -55
- package/docs/en/configure/app/tools/tailwindcss.mdx +0 -98
- package/docs/en/configure/app/tools/terser.mdx +0 -58
- package/docs/en/configure/app/tools/ts-loader.mdx +0 -76
- package/docs/en/configure/app/tools/webpack-chain.mdx +0 -249
- package/docs/en/configure/app/tools/webpack.mdx +0 -305
- package/docs/en/guides/deprecated.md +0 -17
- package/docs/en/guides/topic-detail/micro-frontend/c01-introduction.mdx +0 -27
- package/docs/en/guides/topic-detail/micro-frontend/c02-development.mdx +0 -290
- package/docs/en/guides/topic-detail/micro-frontend/c03-main-app.mdx +0 -298
- package/docs/en/guides/topic-detail/micro-frontend/c04-communicate.mdx +0 -58
- package/docs/en/guides/topic-detail/micro-frontend/c05-mixed-stack.mdx +0 -26
- package/docs/en/guides/topic-detail/model/_meta.json +0 -14
- package/docs/en/guides/topic-detail/model/auto-actions.mdx +0 -85
- package/docs/en/guides/topic-detail/model/computed-state.mdx +0 -148
- package/docs/en/guides/topic-detail/model/define-model.mdx +0 -62
- package/docs/en/guides/topic-detail/model/faq.mdx +0 -35
- package/docs/en/guides/topic-detail/model/manage-effects.mdx +0 -247
- package/docs/en/guides/topic-detail/model/model-communicate.mdx +0 -217
- package/docs/en/guides/topic-detail/model/performance.mdx +0 -167
- package/docs/en/guides/topic-detail/model/quick-start.mdx +0 -117
- package/docs/en/guides/topic-detail/model/redux-integration.mdx +0 -20
- package/docs/en/guides/topic-detail/model/typescript-best-practice.mdx +0 -68
- package/docs/en/guides/topic-detail/model/use-model.mdx +0 -243
- package/docs/en/guides/topic-detail/model/use-out-of-modernjs.mdx +0 -46
- package/docs/en/plugin/official/cli-plugins/plugin-swc.mdx +0 -363
- package/docs/en/plugin/official/cli-plugins/plugin-tailwind.mdx +0 -5
- package/docs/en/plugin/official/rsbuild-plugins/_meta.json +0 -1
- package/docs/en/plugin/official/rsbuild-plugins/plugin-esbuild.mdx +0 -205
- package/docs/en/plugin/official/rsbuild-plugins.mdx +0 -3
- package/docs/en/tutorials/first-app/c01-start.mdx +0 -99
- package/docs/en/tutorials/first-app/c02-component.mdx +0 -60
- package/docs/en/tutorials/first-app/c03-css.mdx +0 -324
- package/docs/en/tutorials/first-app/c04-routes.mdx +0 -172
- package/docs/en/tutorials/first-app/c05-loader.mdx +0 -87
- package/docs/en/tutorials/first-app/c06-model.mdx +0 -278
- package/docs/en/tutorials/first-app/c07-container.mdx +0 -281
- package/docs/en/tutorials/first-app/c08-entries.mdx +0 -135
- package/docs/zh/apis/app/hooks/server/index_.mdx +0 -10
- package/docs/zh/apis/app/hooks/src/index_.mdx +0 -39
- package/docs/zh/apis/app/hooks/src/stories.mdx +0 -16
- package/docs/zh/apis/app/runtime/app/define-config.mdx +0 -67
- package/docs/zh/apis/app/runtime/core/bootstrap.mdx +0 -74
- package/docs/zh/apis/app/runtime/core/create-app.mdx +0 -35
- package/docs/zh/apis/app/runtime/core/use-loader.mdx +0 -89
- package/docs/zh/apis/app/runtime/core/use-module-apps.mdx +0 -179
- package/docs/zh/apis/app/runtime/core/use-runtime-context.mdx +0 -116
- package/docs/zh/apis/app/runtime/model/Provider.mdx +0 -36
- package/docs/zh/apis/app/runtime/model/auto-actions.mdx +0 -122
- package/docs/zh/apis/app/runtime/model/connect.mdx +0 -143
- package/docs/zh/apis/app/runtime/model/create-app.mdx +0 -75
- package/docs/zh/apis/app/runtime/model/create-store.mdx +0 -61
- package/docs/zh/apis/app/runtime/model/handle-effect.mdx +0 -108
- package/docs/zh/apis/app/runtime/model/model_.mdx +0 -201
- package/docs/zh/apis/app/runtime/model/use-local-model.mdx +0 -29
- package/docs/zh/apis/app/runtime/model/use-model.mdx +0 -89
- package/docs/zh/apis/app/runtime/model/use-static-model.mdx +0 -49
- package/docs/zh/apis/app/runtime/model/use-store.mdx +0 -26
- package/docs/zh/apis/app/runtime/ssr/pre-render.mdx +0 -96
- package/docs/zh/apis/app/runtime/web-server/hook.mdx +0 -136
- package/docs/zh/apis/app/runtime/web-server/middleware.mdx +0 -114
- package/docs/zh/apis/app/runtime/web-server/unstable_middleware.mdx +0 -165
- package/docs/zh/components/bff-proxy-path-rewrite.mdx +0 -16
- package/docs/zh/components/bff-proxy-principle.mdx +0 -1
- package/docs/zh/components/builder.mdx +0 -3
- package/docs/zh/components/create-bff-api-app.mdx +0 -25
- package/docs/zh/components/custom-router-micro-frontend.mdx +0 -40
- package/docs/zh/components/enable-micro-frontend.mdx +0 -30
- package/docs/zh/components/enableSwc.mdx +0 -17
- package/docs/zh/components/global-proxy-config.mdx +0 -85
- package/docs/zh/components/global-proxy.mdx +0 -29
- package/docs/zh/components/package-manager.mdx +0 -11
- package/docs/zh/components/reduck-notify.mdx +0 -27
- package/docs/zh/components/reduck-tip.mdx +0 -8
- package/docs/zh/configure/app/auto-load-plugin.mdx +0 -66
- package/docs/zh/configure/app/deploy/microFrontend.mdx +0 -55
- package/docs/zh/configure/app/dev/port.mdx +0 -25
- package/docs/zh/configure/app/dev/proxy.mdx +0 -9
- package/docs/zh/configure/app/experiments/lazy-compilation.mdx +0 -105
- package/docs/zh/configure/app/html/disable-html-folder.mdx +0 -45
- package/docs/zh/configure/app/html/favicon-by-entries.mdx +0 -37
- package/docs/zh/configure/app/html/inject-by-entries.mdx +0 -37
- package/docs/zh/configure/app/html/meta-by-entries.mdx +0 -48
- package/docs/zh/configure/app/html/tags-by-entries.mdx +0 -44
- package/docs/zh/configure/app/html/template-by-entries.mdx +0 -33
- package/docs/zh/configure/app/html/template-parameters-by-entries.mdx +0 -36
- package/docs/zh/configure/app/html/title-by-entries.mdx +0 -37
- package/docs/zh/configure/app/output/css-module-local-ident-name.mdx +0 -21
- package/docs/zh/configure/app/output/disable-css-extract.mdx +0 -16
- package/docs/zh/configure/app/output/disable-filename-hash.mdx +0 -16
- package/docs/zh/configure/app/output/disable-minimize.mdx +0 -14
- package/docs/zh/configure/app/output/disable-node-polyfill.mdx +0 -22
- package/docs/zh/configure/app/output/disable-source-map.mdx +0 -31
- package/docs/zh/configure/app/output/enable-asset-fallback.mdx +0 -36
- package/docs/zh/configure/app/output/enable-inline-scripts.mdx +0 -22
- package/docs/zh/configure/app/output/enable-inline-styles.mdx +0 -22
- package/docs/zh/configure/app/output/enable-latest-decorators.mdx +0 -14
- package/docs/zh/configure/app/performance/transform-lodash.mdx +0 -52
- package/docs/zh/configure/app/runtime/master-app.mdx +0 -38
- package/docs/zh/configure/app/runtime/state.mdx +0 -52
- package/docs/zh/configure/app/source/disable-entry-dirs.mdx +0 -38
- package/docs/zh/configure/app/source/enable-custom-entry.mdx +0 -67
- package/docs/zh/configure/app/source/module-scopes.mdx +0 -72
- package/docs/zh/configure/app/source/resolve-extension-prefix.mdx +0 -57
- package/docs/zh/configure/app/source/resolve-main-fields.mdx +0 -46
- package/docs/zh/configure/app/tools/esbuild.mdx +0 -44
- package/docs/zh/configure/app/tools/pug.mdx +0 -54
- package/docs/zh/configure/app/tools/styled-components.mdx +0 -54
- package/docs/zh/configure/app/tools/tailwindcss.mdx +0 -98
- package/docs/zh/configure/app/tools/terser.mdx +0 -58
- package/docs/zh/configure/app/tools/ts-loader.mdx +0 -76
- package/docs/zh/configure/app/tools/webpack-chain.mdx +0 -253
- package/docs/zh/configure/app/tools/webpack.mdx +0 -305
- package/docs/zh/guides/advanced-features/rspack-start.mdx +0 -154
- package/docs/zh/guides/deprecated.md +0 -19
- package/docs/zh/guides/topic-detail/micro-frontend/c01-introduction.mdx +0 -26
- package/docs/zh/guides/topic-detail/micro-frontend/c02-development.mdx +0 -332
- package/docs/zh/guides/topic-detail/micro-frontend/c03-main-app.mdx +0 -296
- package/docs/zh/guides/topic-detail/micro-frontend/c04-communicate.mdx +0 -58
- package/docs/zh/guides/topic-detail/micro-frontend/c05-mixed-stack.mdx +0 -27
- package/docs/zh/guides/topic-detail/model/_meta.json +0 -14
- package/docs/zh/guides/topic-detail/model/auto-actions.mdx +0 -88
- package/docs/zh/guides/topic-detail/model/computed-state.mdx +0 -147
- package/docs/zh/guides/topic-detail/model/define-model.mdx +0 -63
- package/docs/zh/guides/topic-detail/model/faq.mdx +0 -36
- package/docs/zh/guides/topic-detail/model/manage-effects.mdx +0 -256
- package/docs/zh/guides/topic-detail/model/model-communicate.mdx +0 -217
- package/docs/zh/guides/topic-detail/model/performance.mdx +0 -167
- package/docs/zh/guides/topic-detail/model/quick-start.mdx +0 -117
- package/docs/zh/guides/topic-detail/model/redux-integration.mdx +0 -20
- package/docs/zh/guides/topic-detail/model/typescript-best-practice.mdx +0 -67
- package/docs/zh/guides/topic-detail/model/use-model.mdx +0 -248
- package/docs/zh/guides/topic-detail/model/use-out-of-modernjs.mdx +0 -46
- package/docs/zh/plugin/official/cli-plugins/plugin-swc.mdx +0 -351
- package/docs/zh/plugin/official/cli-plugins/plugin-tailwind.mdx +0 -5
- package/docs/zh/plugin/official/rsbuild-plugins/_meta.json +0 -1
- package/docs/zh/plugin/official/rsbuild-plugins/plugin-esbuild.mdx +0 -201
- package/docs/zh/plugin/official/rsbuild-plugins.mdx +0 -3
- package/docs/zh/tutorials/first-app/c01-start.mdx +0 -99
- package/docs/zh/tutorials/first-app/c02-component.mdx +0 -60
- package/docs/zh/tutorials/first-app/c03-css.mdx +0 -323
- package/docs/zh/tutorials/first-app/c04-routes.mdx +0 -172
- package/docs/zh/tutorials/first-app/c05-loader.mdx +0 -89
- package/docs/zh/tutorials/first-app/c06-model.mdx +0 -274
- package/docs/zh/tutorials/first-app/c07-container.mdx +0 -281
- package/docs/zh/tutorials/first-app/c08-entries.mdx +0 -135
- /package/docs/en/components/{reduck-migration.mdx → auto-upgrade.mdx} +0 -0
- /package/docs/{zh/components/reduck-migration.mdx → en/components/international/platform-support.mdx} +0 -0
|
@@ -21,7 +21,7 @@ export default defineConfig({
|
|
|
21
21
|
For better performance, we only support using this capability combination in Streaming SSR scenarios.
|
|
22
22
|
|
|
23
23
|
:::warning
|
|
24
|
-
|
|
24
|
+
Application-level modules (modules using `createBridgeComponent` and `createRemoteAppComponent`) do not support server-side rendering (SSR). If you need to use SSR functionality, please use component-level module export methods instead.
|
|
25
25
|
:::
|
|
26
26
|
|
|
27
27
|
## Data Fetching
|
|
@@ -56,7 +56,6 @@ In Button, we get the data from the `Props`:
|
|
|
56
56
|
|
|
57
57
|
```ts title="src/components/Button.tsx"
|
|
58
58
|
import React from 'react';
|
|
59
|
-
import './index.css';
|
|
60
59
|
import type { Data } from './Button.data';
|
|
61
60
|
|
|
62
61
|
export const Button = (props: { mfData: Data }) => {
|
|
@@ -68,3 +67,52 @@ export const Button = (props: { mfData: Data }) => {
|
|
|
68
67
|
);
|
|
69
68
|
};
|
|
70
69
|
```
|
|
70
|
+
|
|
71
|
+
## Consuming Components
|
|
72
|
+
|
|
73
|
+
Consumers must use [`createLazyComponent`](https://module-federation.io/practice/bridge/react-bridge/load-component.html#what-is-createlazycomponent) to load remote components and specify the export as the component name.
|
|
74
|
+
|
|
75
|
+
```tsx title="src/routes/page.tsx"
|
|
76
|
+
import type { JSX } from 'react';
|
|
77
|
+
import { getInstance } from '@module-federation/modern-js/runtime';
|
|
78
|
+
import {
|
|
79
|
+
ERROR_TYPE,
|
|
80
|
+
lazyLoadComponentPlugin,
|
|
81
|
+
} from '@module-federation/modern-js/react';
|
|
82
|
+
|
|
83
|
+
const instance = getInstance();
|
|
84
|
+
instance!.registerPlugins([lazyLoadComponentPlugin()]);
|
|
85
|
+
|
|
86
|
+
const Button = instance!.createLazyComponent({
|
|
87
|
+
loader: () => {
|
|
88
|
+
return import('remote/Button');
|
|
89
|
+
},
|
|
90
|
+
loading: 'loading...',
|
|
91
|
+
export: 'Button', // Configure this as the export name of the remote component
|
|
92
|
+
fallback: ({ error, errorType, dataFetchMapKey }) => {
|
|
93
|
+
console.error(error);
|
|
94
|
+
if (errorType === ERROR_TYPE.LOAD_REMOTE) {
|
|
95
|
+
return <div>load remote failed</div>;
|
|
96
|
+
}
|
|
97
|
+
if (errorType === ERROR_TYPE.DATA_FETCH) {
|
|
98
|
+
return (
|
|
99
|
+
<div>
|
|
100
|
+
data fetch failed, the dataFetchMapKey key is: {dataFetchMapKey}
|
|
101
|
+
</div>
|
|
102
|
+
);
|
|
103
|
+
}
|
|
104
|
+
return <div>error type is unknown</div>;
|
|
105
|
+
},
|
|
106
|
+
});
|
|
107
|
+
|
|
108
|
+
const Index = (): JSX.Element => {
|
|
109
|
+
return (
|
|
110
|
+
<div>
|
|
111
|
+
<h1>Basic usage with data fetch</h1>
|
|
112
|
+
<Button />
|
|
113
|
+
</div>
|
|
114
|
+
);
|
|
115
|
+
};
|
|
116
|
+
|
|
117
|
+
export default Index;
|
|
118
|
+
```
|
|
@@ -21,15 +21,7 @@ import { appTools, defineConfig } from '@modern-js/app-tools';
|
|
|
21
21
|
import { moduleFederationPlugin } from '@module-federation/modern-js';
|
|
22
22
|
|
|
23
23
|
export default defineConfig({
|
|
24
|
-
|
|
25
|
-
router: true,
|
|
26
|
-
},
|
|
27
|
-
plugins: [
|
|
28
|
-
appTools({
|
|
29
|
-
bundler: 'rspack',
|
|
30
|
-
}),
|
|
31
|
-
moduleFederationPlugin(),
|
|
32
|
-
],
|
|
24
|
+
plugins: [appTools(), moduleFederationPlugin()],
|
|
33
25
|
});
|
|
34
26
|
```
|
|
35
27
|
|
|
@@ -79,18 +71,10 @@ import { appTools, defineConfig } from '@modern-js/app-tools';
|
|
|
79
71
|
import { moduleFederationPlugin } from '@module-federation/modern-js';
|
|
80
72
|
|
|
81
73
|
export default defineConfig({
|
|
82
|
-
|
|
74
|
+
server: {
|
|
83
75
|
port: 3051,
|
|
84
76
|
},
|
|
85
|
-
|
|
86
|
-
router: true,
|
|
87
|
-
},
|
|
88
|
-
plugins: [
|
|
89
|
-
appTools({
|
|
90
|
-
bundler: 'rspack',
|
|
91
|
-
}),
|
|
92
|
-
moduleFederationPlugin(),
|
|
93
|
-
],
|
|
77
|
+
plugins: [appTools(), moduleFederationPlugin()],
|
|
94
78
|
});
|
|
95
79
|
```
|
|
96
80
|
|
|
@@ -120,7 +104,7 @@ export default createModuleFederationConfig({
|
|
|
120
104
|
Create a new route file `src/routes/remote/page.tsx` and import the producer module:
|
|
121
105
|
|
|
122
106
|
```tsx title="src/routes/remote/page.tsx"
|
|
123
|
-
import React, {
|
|
107
|
+
import React, { Suspense, type JSX } from 'react';
|
|
124
108
|
import { Button } from 'remote/Button';
|
|
125
109
|
|
|
126
110
|
const Index = (): JSX.Element => {
|
|
@@ -195,25 +179,21 @@ export default defineConfig({
|
|
|
195
179
|
server: {
|
|
196
180
|
port: 3051,
|
|
197
181
|
},
|
|
198
|
-
runtime: {
|
|
199
|
-
router: true,
|
|
200
|
-
},
|
|
201
182
|
output: {
|
|
202
183
|
// Now this configuration is only used in the local when you run modern serve command.
|
|
203
184
|
// If you want to deploy the application to the platform, use your own domain name.
|
|
204
185
|
// Module federation will automatically write it to mf-manifest.json, which influences consumer to fetch remoteEntry.js.
|
|
205
186
|
assetPrefix: 'http://127.0.0.1:3051',
|
|
206
187
|
},
|
|
207
|
-
plugins: [
|
|
208
|
-
appTools({
|
|
209
|
-
bundler: 'rspack', // Set to 'webpack' to enable webpack
|
|
210
|
-
}),
|
|
211
|
-
moduleFederationPlugin(),
|
|
212
|
-
],
|
|
188
|
+
plugins: [appTools(), moduleFederationPlugin()],
|
|
213
189
|
});
|
|
214
190
|
```
|
|
215
191
|
|
|
216
|
-
Now, in the producer, run `modern build && modern serve`, and in the consumer, run `modern build && modern serve` to simulate the production environment locally and access the remote modules.
|
|
192
|
+
Now, in the producer, run `modern build && MODERN_MF_AUTO_CORS=true modern serve`, and in the consumer, run `modern build && modern serve` to simulate the production environment locally and access the remote modules.
|
|
193
|
+
|
|
194
|
+
:::tip
|
|
195
|
+
When using the `modern serve` command, you need to set the `MODERN_MF_AUTO_CORS=true` environment variable when starting the producer project to automatically handle CORS issues and ensure that consumers can properly access the producer's remote module resources.
|
|
196
|
+
:::
|
|
217
197
|
|
|
218
198
|
You can refer to this example: [Modern.js & Module Federation Basic Example](https://github.com/web-infra-dev/modern-js-examples/tree/main/examples/module-federation/base).
|
|
219
199
|
|
|
@@ -18,21 +18,9 @@ Modern.js is internally based on [Rsbuild](https://rsbuild.rs/) and encapsulates
|
|
|
18
18
|
|
|
19
19
|
---
|
|
20
20
|
|
|
21
|
-
### How to
|
|
21
|
+
### How to view the final generated Rspack configuration?
|
|
22
22
|
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
If you need to clear the local webpack cache, you can execute the following command:
|
|
26
|
-
|
|
27
|
-
```bash
|
|
28
|
-
rm -rf ./node_modules/.cache
|
|
29
|
-
```
|
|
30
|
-
|
|
31
|
-
---
|
|
32
|
-
|
|
33
|
-
### How to view the final generated webpack / Rspack configuration?
|
|
34
|
-
|
|
35
|
-
Modern.js provides [inspect command](https://modernjs.dev/en/apis/app/commands.html) to view the final Modern.js configuration and webpack / Rspack configuration generated by the project.
|
|
23
|
+
Modern.js provides [inspect command](https://modernjs.dev/en/apis/app/commands.html) to view the final Modern.js configuration and Rspack configuration generated by the project.
|
|
36
24
|
|
|
37
25
|
```bash
|
|
38
26
|
➜ npx modern inspect
|
|
@@ -45,32 +33,6 @@ Inspect config succeed, open following files to view the content:
|
|
|
45
33
|
|
|
46
34
|
---
|
|
47
35
|
|
|
48
|
-
### 'compilation' argument error when webpack compiling?
|
|
49
|
-
|
|
50
|
-
If the following error occurs when compiling, it is usually caused by installing the wrong version of webpack in the project, or installing multiple versions of webpack:
|
|
51
|
-
|
|
52
|
-
```bash
|
|
53
|
-
TypeError: The 'compilation' argument must be an instance of Compilation
|
|
54
|
-
```
|
|
55
|
-
|
|
56
|
-
The webpack version problem has the following situations:
|
|
57
|
-
|
|
58
|
-
1. The webpack dependency is directly declared in the project's package.json, and the version range of the webpack that the Modern.js depends on is different and cannot match the same version.
|
|
59
|
-
2. Multiple npm packages installed in the project all depend on webpack, and the webpack version ranges they depend on are different and cannot match the same version.
|
|
60
|
-
3. Due to the lock mechanism of the package manager, multiple webpack versions are generated in the lock file.
|
|
61
|
-
|
|
62
|
-
In the first case, it is recommended to remove the webpack dependency from the project's package.json. Because Modern.js encapsulates webpack-related capabilities by default, and will pass in the webpack object in the [tools.webpack](/en/configure/app/tools/webpack.html) configuration option. Therefore, in most cases, it is not recommended to install additional webpack dependencies in the project.
|
|
63
|
-
|
|
64
|
-
In the second case, it is recommended to see if you can upgrade an npm package so that its dependent webpack version range is consistent with the Modern.js. It is also possible to manually unify versions through the ability of the package manager, e.g. using [yarn resolutions](https://classic.yarnpkg.com/lang/en/docs/selective-version-resolutions/) or [pnpm overrides](https ://pnpm.io/package_json#pnpmoverrides).
|
|
65
|
-
|
|
66
|
-
If it is the third case, you can use the two methods mentioned in the second case, or you can try to delete the lock file and reinstall it to solve it.
|
|
67
|
-
|
|
68
|
-
:::tip
|
|
69
|
-
Deleting the lock file will automatically upgrade the dependency version in the project to the latest version under the specified scope, please test it thoroughly.
|
|
70
|
-
:::
|
|
71
|
-
|
|
72
|
-
---
|
|
73
|
-
|
|
74
36
|
### Failed import other modules in Monorepo?
|
|
75
37
|
|
|
76
38
|
Due to considerations of compilation performance, by default, the Modern.js does not compile files under `node_modules` or files outside the current project directory.
|
|
@@ -124,7 +86,7 @@ For more information, please refer to issue: [babel#12731](https://github.com/ba
|
|
|
124
86
|
|
|
125
87
|
### The compilation progress bar is stuck, but there is no Error log in the terminal?
|
|
126
88
|
|
|
127
|
-
When the compilation progress bar is stuck, but there is no Error log on the terminal, it is usually because an exception occurred during the compilation. In some cases, when Error is caught by
|
|
89
|
+
When the compilation progress bar is stuck, but there is no Error log on the terminal, it is usually because an exception occurred during the compilation. In some cases, when Error is caught by the build tool or other modules, the error log can not be output correctly. The most common scenario is that there is an exception in the Babel config, which is caught by the build tool, and the build tool swallows the Error in some cases.
|
|
128
90
|
|
|
129
91
|
**Solution:**
|
|
130
92
|
|
|
@@ -188,47 +150,6 @@ export default {
|
|
|
188
150
|
};
|
|
189
151
|
```
|
|
190
152
|
|
|
191
|
-
In addition to the reasons mentioned above, there is another possibility that can cause Babel compilation to hang, which is when Babel compiles a large JS file exceeding 10,000 lines (usually a large file in the node_modules directory that is compiled using `source.include`).
|
|
192
|
-
|
|
193
|
-
When Babel compiles large files, the built-in babel-plugin-styled-components in Modern.js can cause the compilation to hang. There is already a [relevant issue](https://github.com/styled-components/babel-plugin-styled-components/issues/374) in the community .
|
|
194
|
-
|
|
195
|
-
In the future, Modern.js will consider removing the built-in babel-plugin-styled-components. In the current version, you can set [tools.styledComponents](/configure/app/tools/styled-components.html) to `false` to remove this plugin.
|
|
196
|
-
|
|
197
|
-
```ts title="modern.config.ts"
|
|
198
|
-
export default {
|
|
199
|
-
tools: {
|
|
200
|
-
styledComponents: false,
|
|
201
|
-
},
|
|
202
|
-
};
|
|
203
|
-
```
|
|
204
|
-
|
|
205
|
-
---
|
|
206
|
-
|
|
207
|
-
### The webpack cache does not work?
|
|
208
|
-
|
|
209
|
-
Modern.js enables webpack's persistent cache by default.
|
|
210
|
-
|
|
211
|
-
After the first compilation is completed, the cache file will be automatically generated and output to the `./node_modules/.cache/webpack` directory. When the second compilation is performed, the cache is hit and the compilation speed is greatly improved.
|
|
212
|
-
|
|
213
|
-
When configuration files such as `package.json` are modified, the cache is automatically invalidated.
|
|
214
|
-
|
|
215
|
-
If the webpack compilation cache in the project has not taken effect, you can add the following configuration for troubleshooting:
|
|
216
|
-
|
|
217
|
-
```ts
|
|
218
|
-
export default {
|
|
219
|
-
tools: {
|
|
220
|
-
webpack(config) {
|
|
221
|
-
config.infrastructureLogging = {
|
|
222
|
-
...config.infrastructureLogging,
|
|
223
|
-
debug: /webpack\.cache/,
|
|
224
|
-
};
|
|
225
|
-
},
|
|
226
|
-
},
|
|
227
|
-
};
|
|
228
|
-
```
|
|
229
|
-
|
|
230
|
-
After adding the above configuration, webpack will output logs for debugging. Please refer to the logs related to `PackFileCacheStrategy` to understand the cause of cache invalidation.
|
|
231
|
-
|
|
232
153
|
---
|
|
233
154
|
|
|
234
155
|
### Compilation error after referencing a type from lodash
|
|
@@ -6,11 +6,9 @@ sidebar_position: 2
|
|
|
6
6
|
|
|
7
7
|
### Unable to pass command line arguments correctly when using pnpm?
|
|
8
8
|
|
|
9
|
-
|
|
9
|
+
When using pnpm to call the commands in `package.json`, you need to pay attention to how parameters are passed:
|
|
10
10
|
|
|
11
|
-
pnpm
|
|
12
|
-
|
|
13
|
-
When using pnpm to call the commands in `package.json`, if you need to pass parameters to pnpm, you need to put the parameters before the command.
|
|
11
|
+
- **If you need to pass parameters to pnpm**, you need to put the parameters before the command.
|
|
14
12
|
|
|
15
13
|
For example, using the pnpm `--filter` parameter to run the prepare command:
|
|
16
14
|
|
|
@@ -18,7 +16,7 @@ For example, using the pnpm `--filter` parameter to run the prepare command:
|
|
|
18
16
|
pnpm run --filter "./packages/**" prepare
|
|
19
17
|
```
|
|
20
18
|
|
|
21
|
-
If you need to pass parameters to the command
|
|
19
|
+
- **If you need to pass parameters to the command**, you need to put the parameters after the command.
|
|
22
20
|
|
|
23
21
|
For example, in the following `package.json` configuration:
|
|
24
22
|
|
|
@@ -36,28 +34,6 @@ The way to pass parameters when running the command is:
|
|
|
36
34
|
pnpm run command --options
|
|
37
35
|
```
|
|
38
36
|
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
```json
|
|
44
|
-
{
|
|
45
|
-
"scripts": {
|
|
46
|
-
"command": "modern command"
|
|
47
|
-
}
|
|
48
|
-
}
|
|
49
|
-
```
|
|
50
|
-
|
|
51
|
-
If you need to run `modern command --option`:
|
|
52
|
-
|
|
53
|
-
When using pnpm, you need to run `pnpm run command -- --option`.
|
|
54
|
-
|
|
55
|
-
This is because pnpm's handling of command parameters is different from that of Yarn, but similar to that of npm: when the `--` string is not added, the parameters passed are for pnpm; when the `--` string is used, the parameters passed are for running the script.
|
|
56
|
-
|
|
57
|
-
In the above example, the `--option` parameter is passed to `modern command`. If you run `pnpm run command --option`, the `--option` parameter will be passed to pnpm.
|
|
58
|
-
|
|
59
|
-
In summary:
|
|
60
|
-
|
|
61
|
-
**When using pnpm v7, if passing parameters to pnpm, the parameters need to be placed before the command.**
|
|
62
|
-
|
|
63
|
-
**When using pnpm v6, if the parameters are passed to pnpm, `--` is not required; if the parameters are passed to the script, the `--` string needs to be added.**
|
|
37
|
+
:::tip
|
|
38
|
+
Modern.js requires Node.js >= 20.19.5, and pnpm v6 does not support Node.js 20, so please use pnpm v7 or higher.
|
|
39
|
+
:::
|
|
@@ -14,24 +14,24 @@ Here are some basic examples. For detailed usage, please refer to the documentat
|
|
|
14
14
|
|
|
15
15
|
For projects using npm or yarn, you can use the `npm ls` command.
|
|
16
16
|
|
|
17
|
-
For example, running `npm ls @modern-js/
|
|
17
|
+
For example, running `npm ls @modern-js/plugin` will show the following result:
|
|
18
18
|
|
|
19
19
|
```
|
|
20
20
|
project
|
|
21
21
|
└─┬ @modern-js/app-tools@x.y.z
|
|
22
|
-
└── @modern-js/
|
|
22
|
+
└── @modern-js/plugin@x.y.z
|
|
23
23
|
```
|
|
24
24
|
|
|
25
25
|
**pnpm**
|
|
26
26
|
|
|
27
27
|
For projects using pnpm, you can use the `pnpm ls` command.
|
|
28
28
|
|
|
29
|
-
For example, running `pnpm ls @modern-js/
|
|
29
|
+
For example, running `pnpm ls @modern-js/plugin --depth Infinity` will show the following result:
|
|
30
30
|
|
|
31
31
|
```
|
|
32
32
|
devDependencies:
|
|
33
33
|
@modern-js/app-tools x.y.z
|
|
34
|
-
└── @modern-js/
|
|
34
|
+
└── @modern-js/plugin x.y.z
|
|
35
35
|
```
|
|
36
36
|
|
|
37
37
|
---
|
|
@@ -43,24 +43,24 @@ If you encounter the following error message during dependency installation, it
|
|
|
43
43
|
```bash
|
|
44
44
|
The engine "node" is incompatible with this module.
|
|
45
45
|
|
|
46
|
-
Expected version ">=
|
|
46
|
+
Expected version ">=20.19.5". Got "16.20.1"
|
|
47
47
|
```
|
|
48
48
|
|
|
49
|
-
|
|
49
|
+
Modern.js requires Node.js version >= 20.19.5. We strongly recommend using the latest LTS version (such as [Node.js 22 LTS](https://nodejs.org/)) for the best experience.
|
|
50
50
|
|
|
51
51
|
If the Node.js version of the current environment is lower than the above requirement, you can use tools such as [nvm](https://github.com/nvm-sh/nvm) or [fnm](https://github.com/Schniz/fnm) to switch versions.
|
|
52
52
|
|
|
53
53
|
Here is an example of using nvm:
|
|
54
54
|
|
|
55
|
-
```
|
|
56
|
-
# Install Node.js
|
|
57
|
-
nvm install
|
|
55
|
+
```bash
|
|
56
|
+
# Install Node.js 22 LTS
|
|
57
|
+
nvm install 22 --lts
|
|
58
58
|
|
|
59
|
-
# Switch to Node
|
|
60
|
-
nvm use
|
|
59
|
+
# Switch to Node.js 22
|
|
60
|
+
nvm use 22
|
|
61
61
|
|
|
62
|
-
# Set Node
|
|
63
|
-
nvm default
|
|
62
|
+
# Set Node.js 22 as the default version
|
|
63
|
+
nvm alias default 22
|
|
64
64
|
```
|
|
65
65
|
|
|
66
66
|
For local development environments, it is recommended to use [fnm](https://github.com/Schniz/fnm), which has better performance than nvm and has similar usage.
|
|
@@ -77,14 +77,14 @@ Type 'React.ReactNode' is not assignable to type 'import("/node_modules/@types/r
|
|
|
77
77
|
Type '{}' is not assignable to type 'ReactNode'.
|
|
78
78
|
```
|
|
79
79
|
|
|
80
|
-
The reason for this problem is that the ReactNode type definition in React 18 is different from that in React 16/17. If there are multiple different versions of `@types/react` in the project, a ReactNode type conflict will occur, resulting in the above error.
|
|
80
|
+
The reason for this problem is that the ReactNode type definition in React 18+ is different from that in React 16/17. If there are multiple different versions of `@types/react` in the project, a ReactNode type conflict will occur, resulting in the above error.
|
|
81
81
|
|
|
82
82
|
The solution is to lock the `@types/react` and `@types/react-dom` in the project to a unified version, such as `v17`.
|
|
83
83
|
|
|
84
84
|
```json
|
|
85
85
|
{
|
|
86
|
-
"@types/react": "^
|
|
87
|
-
"@types/react-dom": "^
|
|
86
|
+
"@types/react": "^19",
|
|
87
|
+
"@types/react-dom": "^19"
|
|
88
88
|
}
|
|
89
89
|
```
|
|
90
90
|
|
|
@@ -102,12 +102,10 @@ In most cases, peer dependencies warnings will not affect the project operation
|
|
|
102
102
|
|
|
103
103
|
### What is the minimum supported version of React for the Modern.js framework?
|
|
104
104
|
|
|
105
|
-
**
|
|
105
|
+
**Modern.js framework requires React version >= 18.0.0**.
|
|
106
106
|
|
|
107
|
-
- If you are using
|
|
108
|
-
- If you are
|
|
109
|
-
|
|
110
|
-
In future major versions of Modern.js, we will gradually remove support for React 16 and React 17. Therefore, please upgrade to React 18 or higher as soon as possible.
|
|
107
|
+
- **If you are using Modern.js runtime capabilities** (including SSR, Streaming SSR, data loading, routing, etc.), you must use React 18 or higher. React 16 and React 17 are no longer supported.
|
|
108
|
+
- **If you are only using Modern.js build capabilities** (without runtime), React 16 or React 17 may theoretically work, but it is strongly recommended to upgrade to React 18 or higher for the best experience and full feature support.
|
|
111
109
|
|
|
112
110
|
---
|
|
113
111
|
|
|
@@ -118,6 +116,8 @@ Type 'CliPlugin<{}, {}, {}, {}>' is not assignable to type 'CliPlugin<any, {}, {
|
|
|
118
116
|
Types of property 'setup' are incompatible.
|
|
119
117
|
```
|
|
120
118
|
|
|
121
|
-
When you use the Modern.js framework, the above error occurs in the configuration file, it may be due to the inconsistent versions of Modern.js related packages
|
|
119
|
+
When you use the Modern.js framework, the above error occurs in the configuration file, it may be due to the inconsistent versions of Modern.js related packages. You need to manually update all `@modern-js/**` packages to the same version.
|
|
122
120
|
|
|
123
121
|
In the monorepo, the above error may also occur due to inconsistent versions of the Modern.js framework used by different sub-projects.
|
|
122
|
+
|
|
123
|
+
For information on how to unify and upgrade dependency versions, please refer to the [Upgrading](/guides/get-started/upgrade) documentation.
|
|
@@ -13,9 +13,9 @@ CLI plugins need to be configured via the [`plugins`](/configure/app/plugins) fi
|
|
|
13
13
|
A typical CLI plugin structure is as follows:
|
|
14
14
|
|
|
15
15
|
```typescript
|
|
16
|
-
import type {
|
|
16
|
+
import type { CliPlugin, AppTools } from '@modern-js/app-tools';
|
|
17
17
|
|
|
18
|
-
const myCliPlugin = ():
|
|
18
|
+
const myCliPlugin = (): CliPlugin<AppTools> => ({
|
|
19
19
|
name: '@my-org/my-plugin', // Plugin name, ensure uniqueness
|
|
20
20
|
setup: api => {
|
|
21
21
|
// Use the API here to register hooks, add commands, etc.
|
|
@@ -59,7 +59,6 @@ Gets the context information of the Modern.js application.
|
|
|
59
59
|
| `apiDirectory` | `string` | The absolute path to the API module directory (used by BFF) | - |
|
|
60
60
|
| `lambdaDirectory` | `string` | The absolute path to the Lambda module directory (used by BFF) | - |
|
|
61
61
|
| `runtimeConfigFile` | `string` | The name of the runtime configuration file | - |
|
|
62
|
-
| `serverConfigFile` | `string` | The name of the server configuration file | - |
|
|
63
62
|
| `checkedEntries` | `string[]` | Specified entry information | - |
|
|
64
63
|
| `apiOnly` | `boolean` | Whether it is in `apiOnly` mode | - |
|
|
65
64
|
|
|
@@ -133,8 +132,8 @@ Checks if a specified plugin is registered.
|
|
|
133
132
|
- **Example:**
|
|
134
133
|
|
|
135
134
|
```typescript
|
|
136
|
-
if (api.isPluginExists('@modern-js/plugin-
|
|
137
|
-
console.log('
|
|
135
|
+
if (api.isPluginExists('@modern-js/plugin-bff')) {
|
|
136
|
+
console.log('BFF plugin is enabled');
|
|
138
137
|
}
|
|
139
138
|
```
|
|
140
139
|
|
|
@@ -2,34 +2,15 @@
|
|
|
2
2
|
|
|
3
3
|
### Migration Background
|
|
4
4
|
|
|
5
|
-
The Modern.js plugin system is constantly evolving.
|
|
5
|
+
The Modern.js plugin system is constantly evolving. To provide a clearer API and more powerful features, we've optimized the definition and usage of CLI plugins. While the old plugin syntax is still supported for compatibility, we strongly recommend migrating according to this guide to take full advantage of the new plugin system.
|
|
6
6
|
|
|
7
7
|
### Migration Steps Overview
|
|
8
8
|
|
|
9
|
-
1. **
|
|
10
|
-
2. **
|
|
11
|
-
3. **Replace Changed APIs:** Refer to the detailed API mapping table and update your code.
|
|
9
|
+
1. **Adjust Hook Invocation:** Migrate from the `return hooks` pattern to direct `api.xxx` calls.
|
|
10
|
+
2. **Replace Changed APIs:** Refer to the detailed API mapping table and update your code.
|
|
12
11
|
|
|
13
12
|
### Detailed Migration Steps
|
|
14
13
|
|
|
15
|
-
#### Update Plugin Type Definition
|
|
16
|
-
|
|
17
|
-
This is the first and most crucial step of the migration. It ensures that your plugin interacts correctly with the new plugin system.
|
|
18
|
-
|
|
19
|
-
```typescript
|
|
20
|
-
// Old Syntax
|
|
21
|
-
import type { CliPlugin, AppTools } from '@modern-js/app-tools';
|
|
22
|
-
|
|
23
|
-
const plugin: CliPlugin<AppTools<'shared'>> = { ... };
|
|
24
|
-
|
|
25
|
-
// New Syntax
|
|
26
|
-
import type { CliPluginFuture, AppTools } from '@modern-js/app-tools';
|
|
27
|
-
|
|
28
|
-
const plugin: CliPluginFuture<AppTools<'shared'>> = { ... };
|
|
29
|
-
```
|
|
30
|
-
|
|
31
|
-
**Explanation:** The `CliPluginFuture` type is the standard definition for new plugins, providing better type inference and a clearer API structure.
|
|
32
|
-
|
|
33
14
|
#### Adjust Hook Invocation
|
|
34
15
|
|
|
35
16
|
The new plugin system recommends using the `api` object to directly call Hooks. This approach is more intuitive and easier to maintain.
|
|
@@ -38,15 +19,19 @@ The new plugin system recommends using the `api` object to directly call Hooks.
|
|
|
38
19
|
// Old Syntax (return hooks)
|
|
39
20
|
{
|
|
40
21
|
setup: () => ({
|
|
41
|
-
commands({ program }) {
|
|
42
|
-
|
|
22
|
+
commands({ program }) {
|
|
23
|
+
/*...*/
|
|
24
|
+
},
|
|
25
|
+
});
|
|
43
26
|
}
|
|
44
27
|
|
|
45
28
|
// New Syntax (api.xxx)
|
|
46
29
|
{
|
|
47
30
|
setup: api => {
|
|
48
|
-
api.addCommand(({ program }) => {
|
|
49
|
-
|
|
31
|
+
api.addCommand(({ program }) => {
|
|
32
|
+
/*...*/
|
|
33
|
+
});
|
|
34
|
+
};
|
|
50
35
|
}
|
|
51
36
|
```
|
|
52
37
|
|
|
@@ -56,26 +41,26 @@ The new plugin system recommends using the `api` object to directly call Hooks.
|
|
|
56
41
|
|
|
57
42
|
To maintain API consistency and clarity, we've adjusted the names of some APIs. The following table lists all changed APIs and their old and new counterparts:
|
|
58
43
|
|
|
59
|
-
| Old API
|
|
60
|
-
|
|
|
61
|
-
| `useAppContext`
|
|
62
|
-
| `useConfigContext`
|
|
63
|
-
| `useResolvedConfigContext` | `getNormalizedConfig`
|
|
64
|
-
| `beforeConfig`
|
|
65
|
-
| `prepare`
|
|
66
|
-
| `afterPrepare`
|
|
67
|
-
| `beforePrintInstructions
|
|
68
|
-
| `commands`
|
|
69
|
-
| `watchFiles`
|
|
70
|
-
| `fileChange`
|
|
71
|
-
| `beforeCreateCompiler`
|
|
72
|
-
| `afterCreateCompiler`
|
|
73
|
-
| `beforeBuild`
|
|
74
|
-
| `afterBuild`
|
|
75
|
-
| `beforeDev`
|
|
76
|
-
| `afterDev`
|
|
77
|
-
| `beforeExit`
|
|
78
|
-
| `htmlPartials`
|
|
44
|
+
| Old API | New API | Description |
|
|
45
|
+
| :------------------------- | :---------------------------- | :-------------------------------------------------------------------------------------------------------------------------- |
|
|
46
|
+
| `useAppContext` | `getAppContext` | Gets the application context information. |
|
|
47
|
+
| `useConfigContext` | `getConfig` | Gets the configuration defined in the user's configuration file. |
|
|
48
|
+
| `useResolvedConfigContext` | `getNormalizedConfig` | Gets the final configuration after processing by plugins. |
|
|
49
|
+
| `beforeConfig` | (Defined directly in `setup`) | The `beforeConfig` Hook is no longer needed. Write related logic directly in the `setup` function. |
|
|
50
|
+
| `prepare` | `onPrepare` | The preparation stage before running the main process. |
|
|
51
|
+
| `afterPrepare` | `onAfterPrepare` (Deprecated) | Executes after `onPrepare`, but may be deprecated in future versions. It's recommended to merge the logic into `onPrepare`. |
|
|
52
|
+
| `beforePrintInstructions` | `onBeforePrintInstructions` | Executes before printing log messages. |
|
|
53
|
+
| `commands` | `addCommand` | Adds a new CLI command. |
|
|
54
|
+
| `watchFiles` | `addWatchFiles` | Adds files to be watched. |
|
|
55
|
+
| `fileChange` | `onFileChanged` | Listens for file change events. |
|
|
56
|
+
| `beforeCreateCompiler` | `onBeforeCreateCompiler` | Executes before creating the compiler. |
|
|
57
|
+
| `afterCreateCompiler` | `onAfterCreateCompiler` | Executes after creating the compiler. |
|
|
58
|
+
| `beforeBuild` | `onBeforeBuild` | Executes before building. |
|
|
59
|
+
| `afterBuild` | `onAfterBuild` | Executes after building. |
|
|
60
|
+
| `beforeDev` | `onBeforeDev` | Executes before running the `dev` command. |
|
|
61
|
+
| `afterDev` | `onDevCompileDone` | Executes after the `dev` command compilation is complete. |
|
|
62
|
+
| `beforeExit` | `onBeforeExit` | Executes before the process exits. |
|
|
63
|
+
| `htmlPartials` | `modifyHtmlPartials` | Modifies HTML template partials. |
|
|
79
64
|
|
|
80
65
|
**Explanation:** Please carefully review your code and ensure that all old APIs have been replaced with the new APIs.
|
|
81
66
|
|
|
@@ -83,7 +68,7 @@ To maintain API consistency and clarity, we've adjusted the names of some APIs.
|
|
|
83
68
|
|
|
84
69
|
**Q: Will my plugin still work after the migration?**
|
|
85
70
|
|
|
86
|
-
A: As long as you have correctly completed all the steps in this guide, your plugin should work normally.
|
|
71
|
+
A: As long as you have correctly completed all the steps in this guide, your plugin should work normally. If you encounter any problems, please refer to the official Modern.js documentation or seek community support.
|
|
87
72
|
|
|
88
73
|
**Q: Do I have to migrate my plugin immediately?**
|
|
89
74
|
|
|
@@ -95,4 +80,4 @@ A: Please refer to the official Modern.js documentation, especially the section
|
|
|
95
80
|
|
|
96
81
|
### Summary
|
|
97
82
|
|
|
98
|
-
With this detailed migration guide, we hope to help you smoothly migrate your CLI plugins to the new Modern.js plugin system.
|
|
83
|
+
With this detailed migration guide, we hope to help you smoothly migrate your CLI plugins to the new Modern.js plugin system. If you encounter any problems during the migration, please feel free to ask us for help.
|