@modern-js/main-doc 2.69.5 → 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.
Files changed (540) hide show
  1. package/docs/en/{_meta.json → _nav.json} +5 -1
  2. package/docs/en/apis/app/commands.mdx +2 -3
  3. package/docs/en/apis/app/hooks/src/entry.mdx +1 -5
  4. package/docs/en/apis/app/hooks/src/entry.server.mdx +4 -5
  5. package/docs/en/apis/app/hooks/src/routes.mdx +2 -2
  6. package/docs/en/apis/app/runtime/_meta.json +0 -18
  7. package/docs/en/apis/app/runtime/bff/use-hono-context.mdx +2 -2
  8. package/docs/en/apis/app/runtime/router/router.mdx +1 -1
  9. package/docs/en/apis/app/runtime/utility/css-in-js.mdx +3 -2
  10. package/docs/en/community/blog/v2-release-note.mdx +0 -2
  11. package/docs/en/community/contributing-guide.mdx +10 -12
  12. package/docs/en/components/bff-upload.mdx +16 -12
  13. package/docs/en/components/build-output.mdx +45 -0
  14. package/docs/en/components/debug-app.mdx +1 -1
  15. package/docs/en/components/enable-bff-caution.mdx +2 -2
  16. package/docs/en/components/enable-bff.mdx +38 -8
  17. package/docs/en/components/enable-ssg.mdx +48 -0
  18. package/docs/en/components/entry-scan-logic.mdx +7 -0
  19. package/docs/en/components/init-app.mdx +40 -17
  20. package/docs/en/components/international/install-command.mdx +9 -0
  21. package/docs/en/components/international/introduce.mdx +2 -0
  22. package/docs/en/components/module-federation.mdx +4 -4
  23. package/docs/en/components/new-entry-tooltip.mdx +0 -0
  24. package/docs/en/components/nodeVersion.mdx +2 -6
  25. package/docs/en/components/prerequisites.mdx +1 -1
  26. package/docs/en/components/ua-polyfill.mdx +16 -12
  27. package/docs/en/components/upgrade-browserslist.mdx +0 -0
  28. package/docs/en/configure/_meta.json +7 -8
  29. package/docs/en/configure/app/bff/cross-project.mdx +24 -0
  30. package/docs/en/configure/app/dev/lazy-compilation.mdx +45 -0
  31. package/docs/en/configure/app/dev/server.mdx +103 -0
  32. package/docs/en/configure/app/dev/setup-middlewares.mdx +4 -22
  33. package/docs/en/configure/app/html/app-icon.mdx +1 -23
  34. package/docs/en/configure/app/output/inline-scripts.mdx +1 -1
  35. package/docs/en/configure/app/output/override-browserslist.mdx +6 -4
  36. package/docs/en/configure/app/output/source-map.mdx +6 -3
  37. package/docs/en/configure/app/output/ssg.mdx +12 -43
  38. package/docs/en/configure/app/output/ssgByEntries.mdx +93 -0
  39. package/docs/en/configure/app/performance/build-cache.mdx +0 -4
  40. package/docs/en/configure/app/resolve/alias-strategy.mdx +14 -0
  41. package/docs/en/configure/app/resolve/alias.mdx +13 -0
  42. package/docs/en/configure/app/resolve/condition-names.mdx +18 -0
  43. package/docs/en/configure/app/resolve/dedupe.mdx +13 -0
  44. package/docs/en/configure/app/resolve/extensions.mdx +18 -0
  45. package/docs/en/configure/app/runtime/0-intro.mdx +2 -51
  46. package/docs/en/configure/app/security/check-syntax.mdx +1 -1
  47. package/docs/en/configure/app/server/port.mdx +1 -21
  48. package/docs/en/configure/app/server/rsc.mdx +30 -0
  49. package/docs/en/configure/app/server/ssr.mdx +20 -9
  50. package/docs/en/configure/app/source/decorators.mdx +4 -2
  51. package/docs/en/configure/app/source/entries.mdx +0 -2
  52. package/docs/en/configure/app/source/main-entry-name.mdx +4 -4
  53. package/docs/en/configure/app/source/transform-import.mdx +1 -59
  54. package/docs/en/configure/app/tools/bundler-chain.mdx +5 -5
  55. package/docs/en/configure/app/tools/css-extract.mdx +1 -1
  56. package/docs/en/configure/app/tools/dev-server.mdx +14 -248
  57. package/docs/en/configure/app/tools/html-plugin.mdx +3 -3
  58. package/docs/en/configure/app/tools/lightningcss-loader.mdx +0 -1
  59. package/docs/en/configure/app/tools/swc.mdx +1 -43
  60. package/docs/en/configure/app/usage.mdx +7 -17
  61. package/docs/en/guides/_meta.json +1 -2
  62. package/docs/en/guides/advanced-features/_meta.json +6 -0
  63. package/docs/en/guides/advanced-features/bff/cross-project.mdx +1 -7
  64. package/docs/en/guides/advanced-features/bff/extend-server.mdx +18 -3
  65. package/docs/en/guides/advanced-features/bff/frameworks.mdx +1 -1
  66. package/docs/en/guides/advanced-features/bff/function.mdx +2 -6
  67. package/docs/en/guides/advanced-features/bff/sdk.mdx +3 -3
  68. package/docs/en/guides/advanced-features/build-performance.mdx +23 -26
  69. package/docs/en/guides/advanced-features/compatibility.mdx +53 -9
  70. package/docs/en/guides/advanced-features/international/_meta.json +11 -0
  71. package/docs/en/guides/advanced-features/international/advanced.mdx +193 -0
  72. package/docs/en/guides/advanced-features/international/api.mdx +400 -0
  73. package/docs/en/guides/advanced-features/international/basic.mdx +417 -0
  74. package/docs/en/guides/advanced-features/international/best-practices.mdx +135 -0
  75. package/docs/en/guides/advanced-features/international/configuration.mdx +437 -0
  76. package/docs/en/guides/advanced-features/international/locale-detection.mdx +276 -0
  77. package/docs/en/guides/advanced-features/international/quick-start.mdx +154 -0
  78. package/docs/en/guides/advanced-features/international/resource-loading.mdx +417 -0
  79. package/docs/en/guides/advanced-features/international/routing.mdx +212 -0
  80. package/docs/en/guides/advanced-features/international.mdx +37 -0
  81. package/docs/en/guides/advanced-features/low-level.mdx +21 -16
  82. package/docs/en/guides/advanced-features/page-performance/code-split.mdx +4 -4
  83. package/docs/en/guides/advanced-features/page-performance/inline-assets.mdx +4 -4
  84. package/docs/en/guides/advanced-features/page-performance/optimize-bundle.mdx +7 -21
  85. package/docs/en/guides/advanced-features/page-performance/react-compiler.mdx +1 -8
  86. package/docs/en/guides/advanced-features/rspack-start.mdx +2 -22
  87. package/docs/en/guides/advanced-features/server-monitor/logger.mdx +0 -4
  88. package/docs/en/guides/advanced-features/server-monitor/monitors.mdx +62 -34
  89. package/docs/en/guides/advanced-features/web-server.mdx +82 -299
  90. package/docs/en/guides/basic-features/_meta.json +6 -1
  91. package/docs/en/guides/basic-features/css/css-in-js.mdx +46 -11
  92. package/docs/en/guides/basic-features/css/css-modules.mdx +5 -17
  93. package/docs/en/guides/basic-features/css/css.mdx +3 -3
  94. package/docs/en/guides/basic-features/css/tailwindcss.mdx +5 -89
  95. package/docs/en/guides/basic-features/data/data-cache.mdx +5 -1
  96. package/docs/en/guides/basic-features/data/data-fetch.mdx +4 -4
  97. package/docs/en/guides/basic-features/data/data-write.mdx +2 -2
  98. package/docs/en/guides/basic-features/debug/mock.mdx +4 -1
  99. package/docs/en/guides/basic-features/debug/proxy.mdx +0 -8
  100. package/docs/en/guides/basic-features/debug/rsdoctor.mdx +5 -5
  101. package/docs/en/guides/basic-features/deploy.mdx +25 -18
  102. package/docs/en/guides/basic-features/env-vars.mdx +1 -1
  103. package/docs/en/guides/basic-features/html.mdx +1 -1
  104. package/docs/en/guides/basic-features/output-files.mdx +3 -3
  105. package/docs/en/guides/basic-features/render/_meta.json +1 -1
  106. package/docs/en/guides/basic-features/render/before-render.mdx +16 -23
  107. package/docs/en/guides/basic-features/render/overview.mdx +51 -0
  108. package/docs/en/guides/basic-features/render/rsc.mdx +394 -0
  109. package/docs/en/guides/basic-features/render/ssg.mdx +26 -62
  110. package/docs/en/guides/basic-features/render/ssr-cache.mdx +6 -6
  111. package/docs/en/guides/basic-features/render/ssr.mdx +31 -31
  112. package/docs/en/guides/basic-features/render/streaming-ssr.mdx +29 -9
  113. package/docs/en/guides/basic-features/routes/_meta.json +1 -0
  114. package/docs/en/guides/basic-features/routes/config-routes.mdx +427 -0
  115. package/docs/en/guides/basic-features/{routes.mdx → routes/routes.mdx} +7 -110
  116. package/docs/en/guides/basic-features/static-assets/json-files.mdx +21 -3
  117. package/docs/en/guides/basic-features/static-assets.mdx +2 -2
  118. package/docs/en/guides/concept/builder.mdx +24 -9
  119. package/docs/en/guides/concept/entries.mdx +139 -147
  120. package/docs/en/guides/get-started/glossary.mdx +0 -18
  121. package/docs/en/guides/get-started/introduction.mdx +1 -4
  122. package/docs/en/guides/get-started/quick-start.mdx +8 -73
  123. package/docs/en/guides/get-started/tech-stack.mdx +7 -25
  124. package/docs/en/guides/get-started/upgrade.mdx +30 -23
  125. package/docs/en/guides/topic-detail/_meta.json +0 -12
  126. package/docs/en/guides/topic-detail/module-federation/_meta.json +1 -1
  127. package/docs/en/guides/topic-detail/module-federation/application.mdx +16 -15
  128. package/docs/en/guides/topic-detail/module-federation/i18n.mdx +670 -0
  129. package/docs/en/guides/topic-detail/module-federation/introduce.mdx +5 -4
  130. package/docs/en/guides/topic-detail/module-federation/ssr.mdx +50 -2
  131. package/docs/en/guides/topic-detail/module-federation/usage.mdx +10 -30
  132. package/docs/en/guides/troubleshooting/builder.mdx +3 -82
  133. package/docs/en/guides/troubleshooting/cli.mdx +6 -30
  134. package/docs/en/guides/troubleshooting/dependencies.mdx +22 -22
  135. package/docs/en/plugin/cli-plugins/api.mdx +4 -5
  136. package/docs/en/plugin/cli-plugins/migration.mdx +33 -48
  137. package/docs/en/plugin/introduction.mdx +39 -27
  138. package/docs/en/plugin/official/_meta.json +0 -5
  139. package/docs/en/plugin/official/cli-plugins/_meta.json +1 -1
  140. package/docs/en/plugin/official/cli-plugins/plugin-styled-components.mdx +5 -0
  141. package/docs/en/plugin/official/cli-plugins.mdx +0 -2
  142. package/docs/en/plugin/plugin-system.mdx +68 -61
  143. package/docs/en/plugin/runtime-plugins/api.mdx +62 -59
  144. package/docs/en/plugin/runtime-plugins/migration.mdx +29 -20
  145. package/docs/en/tutorials/_meta.json +0 -10
  146. package/docs/en/tutorials/examples/csr-auth.mdx +1 -1
  147. package/docs/en/tutorials/foundations/introduction.mdx +9 -25
  148. package/docs/zh/{_meta.json → _nav.json} +10 -6
  149. package/docs/zh/apis/app/commands.mdx +2 -3
  150. package/docs/zh/apis/app/hooks/src/entry.mdx +1 -5
  151. package/docs/zh/apis/app/hooks/src/entry.server.mdx +4 -5
  152. package/docs/zh/apis/app/hooks/src/routes.mdx +2 -2
  153. package/docs/zh/apis/app/runtime/_meta.json +0 -18
  154. package/docs/zh/apis/app/runtime/bff/use-hono-context.mdx +2 -2
  155. package/docs/zh/apis/app/runtime/utility/css-in-js.mdx +3 -2
  156. package/docs/zh/community/blog/v2-release-note.mdx +0 -2
  157. package/docs/zh/community/contributing-guide.mdx +10 -12
  158. package/docs/zh/components/auto-upgrade.mdx +0 -0
  159. package/docs/zh/components/bff-upload.mdx +8 -5
  160. package/docs/zh/components/build-output.mdx +45 -0
  161. package/docs/zh/components/debug-app.mdx +1 -1
  162. package/docs/zh/components/enable-bff-caution.mdx +1 -1
  163. package/docs/zh/components/enable-bff.mdx +37 -8
  164. package/docs/zh/components/enable-ssg.mdx +47 -0
  165. package/docs/zh/components/entry-scan-logic.mdx +7 -0
  166. package/docs/zh/components/init-app.mdx +40 -18
  167. package/docs/zh/components/international/install-command.mdx +8 -0
  168. package/docs/zh/components/international/introduce.mdx +2 -0
  169. package/docs/zh/components/international/platform-support.mdx +0 -0
  170. package/docs/zh/components/module-federation.mdx +4 -4
  171. package/docs/zh/components/new-entry-tooltip.mdx +0 -0
  172. package/docs/zh/components/nodeVersion.mdx +3 -7
  173. package/docs/zh/components/prerequisites.mdx +1 -1
  174. package/docs/zh/components/self-route-example.mdx +3 -3
  175. package/docs/zh/components/ua-polyfill.mdx +11 -6
  176. package/docs/zh/components/upgrade-browserslist.mdx +0 -0
  177. package/docs/zh/configure/_meta.json +7 -8
  178. package/docs/zh/configure/app/bff/cross-project.mdx +24 -0
  179. package/docs/zh/configure/app/dev/lazy-compilation.mdx +44 -0
  180. package/docs/zh/configure/app/dev/server.mdx +104 -0
  181. package/docs/zh/configure/app/dev/setup-middlewares.mdx +4 -23
  182. package/docs/zh/configure/app/html/app-icon.mdx +1 -23
  183. package/docs/zh/configure/app/output/inline-scripts.mdx +1 -1
  184. package/docs/zh/configure/app/output/override-browserslist.mdx +3 -3
  185. package/docs/zh/configure/app/output/source-map.mdx +10 -3
  186. package/docs/zh/configure/app/output/ssg.mdx +13 -45
  187. package/docs/zh/configure/app/output/ssgByEntries.mdx +94 -0
  188. package/docs/zh/configure/app/performance/build-cache.mdx +0 -4
  189. package/docs/zh/configure/app/resolve/alias-strategy.mdx +14 -0
  190. package/docs/zh/configure/app/resolve/alias.mdx +13 -0
  191. package/docs/zh/configure/app/resolve/condition-names.mdx +18 -0
  192. package/docs/zh/configure/app/resolve/dedupe.mdx +14 -0
  193. package/docs/zh/configure/app/resolve/extensions.mdx +18 -0
  194. package/docs/zh/configure/app/runtime/0-intro.mdx +2 -53
  195. package/docs/zh/configure/app/security/check-syntax.mdx +1 -1
  196. package/docs/zh/configure/app/server/port.mdx +2 -21
  197. package/docs/zh/configure/app/server/rsc.mdx +30 -0
  198. package/docs/zh/configure/app/server/ssr.mdx +21 -11
  199. package/docs/zh/configure/app/source/decorators.mdx +4 -4
  200. package/docs/zh/configure/app/source/entries.mdx +0 -2
  201. package/docs/zh/configure/app/source/main-entry-name.mdx +4 -4
  202. package/docs/zh/configure/app/source/transform-import.mdx +1 -59
  203. package/docs/zh/configure/app/tools/bundler-chain.mdx +6 -6
  204. package/docs/zh/configure/app/tools/css-extract.mdx +1 -1
  205. package/docs/zh/configure/app/tools/dev-server.mdx +14 -248
  206. package/docs/zh/configure/app/tools/html-plugin.mdx +3 -2
  207. package/docs/zh/configure/app/tools/lightningcss-loader.mdx +0 -1
  208. package/docs/zh/configure/app/tools/swc.mdx +1 -43
  209. package/docs/zh/configure/app/usage.mdx +8 -18
  210. package/docs/zh/guides/_meta.json +5 -1
  211. package/docs/zh/guides/advanced-features/_meta.json +6 -1
  212. package/docs/zh/guides/advanced-features/bff/cross-project.mdx +8 -16
  213. package/docs/zh/guides/advanced-features/bff/extend-server.mdx +25 -8
  214. package/docs/zh/guides/advanced-features/bff/frameworks.mdx +1 -1
  215. package/docs/zh/guides/advanced-features/bff/function.mdx +7 -12
  216. package/docs/zh/guides/advanced-features/bff/sdk.mdx +4 -4
  217. package/docs/zh/guides/advanced-features/build-performance.mdx +23 -30
  218. package/docs/zh/guides/advanced-features/compatibility.mdx +44 -0
  219. package/docs/zh/guides/advanced-features/international/_meta.json +11 -0
  220. package/docs/zh/guides/advanced-features/international/advanced.mdx +193 -0
  221. package/docs/zh/guides/advanced-features/international/api.mdx +400 -0
  222. package/docs/zh/guides/advanced-features/international/basic.mdx +416 -0
  223. package/docs/zh/guides/advanced-features/international/best-practices.mdx +135 -0
  224. package/docs/zh/guides/advanced-features/international/configuration.mdx +441 -0
  225. package/docs/zh/guides/advanced-features/international/locale-detection.mdx +304 -0
  226. package/docs/zh/guides/advanced-features/international/quick-start.mdx +149 -0
  227. package/docs/zh/guides/advanced-features/international/resource-loading.mdx +417 -0
  228. package/docs/zh/guides/advanced-features/international/routing.mdx +212 -0
  229. package/docs/zh/guides/advanced-features/international.mdx +36 -0
  230. package/docs/zh/guides/advanced-features/low-level.mdx +21 -16
  231. package/docs/zh/guides/advanced-features/page-performance/code-split.mdx +3 -3
  232. package/docs/zh/guides/advanced-features/page-performance/inline-assets.mdx +4 -4
  233. package/docs/zh/guides/advanced-features/page-performance/optimize-bundle.mdx +7 -21
  234. package/docs/zh/guides/advanced-features/page-performance/react-compiler.mdx +1 -8
  235. package/docs/zh/guides/advanced-features/server-monitor/logger.mdx +0 -4
  236. package/docs/zh/guides/advanced-features/server-monitor/monitors.mdx +63 -35
  237. package/docs/zh/guides/advanced-features/web-server.mdx +79 -300
  238. package/docs/zh/guides/basic-features/_meta.json +6 -1
  239. package/docs/zh/guides/basic-features/css/css-in-js.mdx +40 -5
  240. package/docs/zh/guides/basic-features/css/css-modules.mdx +6 -17
  241. package/docs/zh/guides/basic-features/css/css.mdx +2 -2
  242. package/docs/zh/guides/basic-features/css/tailwindcss.mdx +6 -90
  243. package/docs/zh/guides/basic-features/data/data-cache.mdx +8 -5
  244. package/docs/zh/guides/basic-features/data/data-fetch.mdx +6 -5
  245. package/docs/zh/guides/basic-features/data/data-write.mdx +4 -4
  246. package/docs/zh/guides/basic-features/debug/mock.mdx +4 -1
  247. package/docs/zh/guides/basic-features/debug/proxy.mdx +0 -8
  248. package/docs/zh/guides/basic-features/debug/rsdoctor.mdx +6 -6
  249. package/docs/zh/guides/basic-features/deploy.mdx +24 -20
  250. package/docs/zh/guides/basic-features/env-vars.mdx +1 -1
  251. package/docs/zh/guides/basic-features/html.mdx +2 -2
  252. package/docs/zh/guides/basic-features/output-files.mdx +3 -3
  253. package/docs/zh/guides/basic-features/render/_meta.json +1 -1
  254. package/docs/zh/guides/basic-features/render/before-render.mdx +17 -24
  255. package/docs/zh/guides/basic-features/render/overview.mdx +52 -0
  256. package/docs/zh/guides/basic-features/render/rsc.mdx +413 -0
  257. package/docs/zh/guides/basic-features/render/ssg.mdx +27 -69
  258. package/docs/zh/guides/basic-features/render/ssr-cache.mdx +5 -5
  259. package/docs/zh/guides/basic-features/render/ssr.mdx +34 -31
  260. package/docs/zh/guides/basic-features/render/streaming-ssr.mdx +34 -14
  261. package/docs/zh/guides/basic-features/routes/_meta.json +1 -0
  262. package/docs/zh/guides/basic-features/routes/config-routes.mdx +426 -0
  263. package/docs/zh/guides/basic-features/{routes.mdx → routes/routes.mdx} +8 -114
  264. package/docs/zh/guides/basic-features/static-assets/json-files.mdx +21 -3
  265. package/docs/zh/guides/basic-features/static-assets.mdx +2 -2
  266. package/docs/zh/guides/basic-features/testing/cypress.mdx +5 -5
  267. package/docs/zh/guides/basic-features/testing/jest.mdx +12 -12
  268. package/docs/zh/guides/concept/builder.mdx +24 -9
  269. package/docs/zh/guides/concept/entries.mdx +95 -92
  270. package/docs/zh/guides/get-started/glossary.mdx +0 -18
  271. package/docs/zh/guides/get-started/introduction.mdx +1 -5
  272. package/docs/zh/guides/get-started/quick-start.mdx +5 -72
  273. package/docs/zh/guides/get-started/tech-stack.mdx +8 -26
  274. package/docs/zh/guides/get-started/upgrade.mdx +30 -23
  275. package/docs/zh/guides/topic-detail/_meta.json +0 -12
  276. package/docs/zh/guides/topic-detail/module-federation/_meta.json +1 -1
  277. package/docs/zh/guides/topic-detail/module-federation/application.mdx +18 -16
  278. package/docs/zh/guides/topic-detail/module-federation/i18n.mdx +623 -0
  279. package/docs/zh/guides/topic-detail/module-federation/introduce.mdx +4 -4
  280. package/docs/zh/guides/topic-detail/module-federation/ssr.mdx +51 -5
  281. package/docs/zh/guides/topic-detail/module-federation/usage.mdx +11 -32
  282. package/docs/zh/guides/troubleshooting/builder.mdx +3 -84
  283. package/docs/zh/guides/troubleshooting/cli.mdx +6 -30
  284. package/docs/zh/guides/troubleshooting/dependencies.mdx +23 -23
  285. package/docs/zh/guides/upgrade/_meta.json +1 -0
  286. package/docs/zh/guides/upgrade/config.mdx +809 -0
  287. package/docs/zh/guides/upgrade/entry.mdx +463 -0
  288. package/docs/zh/guides/upgrade/other.md +90 -0
  289. package/docs/zh/guides/upgrade/overview.mdx +36 -0
  290. package/docs/zh/guides/upgrade/tailwindcss.mdx +130 -0
  291. package/docs/zh/guides/upgrade/web-server.md +93 -0
  292. package/docs/zh/plugin/cli-plugins/api.mdx +4 -5
  293. package/docs/zh/plugin/cli-plugins/migration.mdx +30 -45
  294. package/docs/zh/plugin/introduction.mdx +36 -24
  295. package/docs/zh/plugin/official/_meta.json +0 -5
  296. package/docs/zh/plugin/official/cli-plugins/_meta.json +1 -1
  297. package/docs/zh/plugin/official/cli-plugins/plugin-styled-components.mdx +5 -0
  298. package/docs/zh/plugin/official/cli-plugins.mdx +0 -2
  299. package/docs/zh/plugin/plugin-system.mdx +45 -42
  300. package/docs/zh/plugin/runtime-plugins/api.mdx +58 -56
  301. package/docs/zh/plugin/runtime-plugins/migration.mdx +26 -17
  302. package/docs/zh/tutorials/_meta.json +0 -10
  303. package/docs/zh/tutorials/examples/csr-auth.mdx +1 -1
  304. package/docs/zh/tutorials/foundations/introduction.mdx +8 -25
  305. package/i18n.json +0 -16
  306. package/package.json +12 -12
  307. package/rspress.config.ts +5 -8
  308. package/src/components/ContentCard/index.module.scss +11 -7
  309. package/src/components/ContentCard/index.tsx +1 -1
  310. package/src/components/FeatureLayout/index.module.css +1 -1
  311. package/src/components/Footer/index.tsx +2 -14
  312. package/src/components/Footer/styles.module.scss +5 -5
  313. package/src/components/ListCard/index.tsx +1 -1
  314. package/src/components/RandomMemberList/index.tsx +1 -1
  315. package/src/components/RsbuildLink/index.tsx +1 -1
  316. package/src/components/Sandpack/index.tsx +1 -1
  317. package/src/custom.scss +15 -0
  318. package/src/i18n/enUS.ts +2 -4
  319. package/src/i18n/index.ts +1 -1
  320. package/src/i18n/zhCN.ts +2 -4
  321. package/src/index.ts +2 -1
  322. package/src/pages/index.module.scss +59 -41
  323. package/src/pages/index.tsx +9 -24
  324. package/docs/en/apis/app/hooks/server/index_.mdx +0 -10
  325. package/docs/en/apis/app/hooks/src/index_.mdx +0 -38
  326. package/docs/en/apis/app/hooks/src/stories.mdx +0 -16
  327. package/docs/en/apis/app/runtime/app/define-config.mdx +0 -67
  328. package/docs/en/apis/app/runtime/core/bootstrap.mdx +0 -74
  329. package/docs/en/apis/app/runtime/core/create-app.mdx +0 -49
  330. package/docs/en/apis/app/runtime/core/use-loader.mdx +0 -89
  331. package/docs/en/apis/app/runtime/core/use-module-apps.mdx +0 -140
  332. package/docs/en/apis/app/runtime/core/use-runtime-context.mdx +0 -116
  333. package/docs/en/apis/app/runtime/model/Provider.mdx +0 -36
  334. package/docs/en/apis/app/runtime/model/auto-actions.mdx +0 -122
  335. package/docs/en/apis/app/runtime/model/connect.mdx +0 -146
  336. package/docs/en/apis/app/runtime/model/create-app.mdx +0 -75
  337. package/docs/en/apis/app/runtime/model/create-store.mdx +0 -61
  338. package/docs/en/apis/app/runtime/model/handle-effect.mdx +0 -107
  339. package/docs/en/apis/app/runtime/model/model_.mdx +0 -198
  340. package/docs/en/apis/app/runtime/model/use-local-model.mdx +0 -29
  341. package/docs/en/apis/app/runtime/model/use-model.mdx +0 -89
  342. package/docs/en/apis/app/runtime/model/use-static-model.mdx +0 -51
  343. package/docs/en/apis/app/runtime/model/use-store.mdx +0 -26
  344. package/docs/en/apis/app/runtime/ssr/pre-render.mdx +0 -96
  345. package/docs/en/apis/app/runtime/web-server/hook.mdx +0 -134
  346. package/docs/en/apis/app/runtime/web-server/middleware.mdx +0 -113
  347. package/docs/en/apis/app/runtime/web-server/unstable_middleware.mdx +0 -167
  348. package/docs/en/components/bff-proxy-path-rewrite.mdx +0 -16
  349. package/docs/en/components/bff-proxy-principle.mdx +0 -1
  350. package/docs/en/components/builder.mdx +0 -3
  351. package/docs/en/components/create-bff-api-app.mdx +0 -25
  352. package/docs/en/components/custom-router-micro-frontend.mdx +0 -40
  353. package/docs/en/components/enable-micro-frontend.mdx +0 -30
  354. package/docs/en/components/enableSwc.mdx +0 -17
  355. package/docs/en/components/global-proxy-config.mdx +0 -85
  356. package/docs/en/components/global-proxy.mdx +0 -29
  357. package/docs/en/components/package-manager.mdx +0 -11
  358. package/docs/en/components/reduck-notify.mdx +0 -27
  359. package/docs/en/components/reduck-tip.mdx +0 -8
  360. package/docs/en/configure/app/auto-load-plugin.mdx +0 -66
  361. package/docs/en/configure/app/deploy/microFrontend.mdx +0 -53
  362. package/docs/en/configure/app/dev/port.mdx +0 -25
  363. package/docs/en/configure/app/dev/proxy.mdx +0 -9
  364. package/docs/en/configure/app/experiments/lazy-compilation.mdx +0 -106
  365. package/docs/en/configure/app/html/disable-html-folder.mdx +0 -46
  366. package/docs/en/configure/app/html/favicon-by-entries.mdx +0 -36
  367. package/docs/en/configure/app/html/inject-by-entries.mdx +0 -36
  368. package/docs/en/configure/app/html/meta-by-entries.mdx +0 -48
  369. package/docs/en/configure/app/html/tags-by-entries.mdx +0 -44
  370. package/docs/en/configure/app/html/template-by-entries.mdx +0 -33
  371. package/docs/en/configure/app/html/template-parameters-by-entries.mdx +0 -35
  372. package/docs/en/configure/app/html/title-by-entries.mdx +0 -37
  373. package/docs/en/configure/app/output/css-module-local-ident-name.mdx +0 -21
  374. package/docs/en/configure/app/output/disable-css-extract.mdx +0 -16
  375. package/docs/en/configure/app/output/disable-filename-hash.mdx +0 -16
  376. package/docs/en/configure/app/output/disable-minimize.mdx +0 -14
  377. package/docs/en/configure/app/output/disable-node-polyfill.mdx +0 -22
  378. package/docs/en/configure/app/output/disable-source-map.mdx +0 -31
  379. package/docs/en/configure/app/output/enable-asset-fallback.mdx +0 -36
  380. package/docs/en/configure/app/output/enable-inline-scripts.mdx +0 -22
  381. package/docs/en/configure/app/output/enable-inline-styles.mdx +0 -22
  382. package/docs/en/configure/app/output/enable-latest-decorators.mdx +0 -14
  383. package/docs/en/configure/app/performance/transform-lodash.mdx +0 -52
  384. package/docs/en/configure/app/runtime/master-app.mdx +0 -36
  385. package/docs/en/configure/app/runtime/state.mdx +0 -52
  386. package/docs/en/configure/app/source/disable-entry-dirs.mdx +0 -38
  387. package/docs/en/configure/app/source/enable-custom-entry.mdx +0 -68
  388. package/docs/en/configure/app/source/module-scopes.mdx +0 -72
  389. package/docs/en/configure/app/source/resolve-extension-prefix.mdx +0 -55
  390. package/docs/en/configure/app/source/resolve-main-fields.mdx +0 -46
  391. package/docs/en/configure/app/tools/esbuild.mdx +0 -44
  392. package/docs/en/configure/app/tools/pug.mdx +0 -54
  393. package/docs/en/configure/app/tools/styled-components.mdx +0 -55
  394. package/docs/en/configure/app/tools/tailwindcss.mdx +0 -98
  395. package/docs/en/configure/app/tools/terser.mdx +0 -58
  396. package/docs/en/configure/app/tools/ts-loader.mdx +0 -76
  397. package/docs/en/configure/app/tools/webpack-chain.mdx +0 -249
  398. package/docs/en/configure/app/tools/webpack.mdx +0 -305
  399. package/docs/en/guides/deprecated.md +0 -17
  400. package/docs/en/guides/topic-detail/micro-frontend/c01-introduction.mdx +0 -27
  401. package/docs/en/guides/topic-detail/micro-frontend/c02-development.mdx +0 -290
  402. package/docs/en/guides/topic-detail/micro-frontend/c03-main-app.mdx +0 -298
  403. package/docs/en/guides/topic-detail/micro-frontend/c04-communicate.mdx +0 -58
  404. package/docs/en/guides/topic-detail/micro-frontend/c05-mixed-stack.mdx +0 -26
  405. package/docs/en/guides/topic-detail/model/_meta.json +0 -14
  406. package/docs/en/guides/topic-detail/model/auto-actions.mdx +0 -85
  407. package/docs/en/guides/topic-detail/model/computed-state.mdx +0 -148
  408. package/docs/en/guides/topic-detail/model/define-model.mdx +0 -62
  409. package/docs/en/guides/topic-detail/model/faq.mdx +0 -35
  410. package/docs/en/guides/topic-detail/model/manage-effects.mdx +0 -247
  411. package/docs/en/guides/topic-detail/model/model-communicate.mdx +0 -217
  412. package/docs/en/guides/topic-detail/model/performance.mdx +0 -167
  413. package/docs/en/guides/topic-detail/model/quick-start.mdx +0 -117
  414. package/docs/en/guides/topic-detail/model/redux-integration.mdx +0 -20
  415. package/docs/en/guides/topic-detail/model/typescript-best-practice.mdx +0 -68
  416. package/docs/en/guides/topic-detail/model/use-model.mdx +0 -243
  417. package/docs/en/guides/topic-detail/model/use-out-of-modernjs.mdx +0 -46
  418. package/docs/en/plugin/official/cli-plugins/plugin-swc.mdx +0 -363
  419. package/docs/en/plugin/official/cli-plugins/plugin-tailwind.mdx +0 -5
  420. package/docs/en/plugin/official/rsbuild-plugins/_meta.json +0 -1
  421. package/docs/en/plugin/official/rsbuild-plugins/plugin-esbuild.mdx +0 -205
  422. package/docs/en/plugin/official/rsbuild-plugins.mdx +0 -3
  423. package/docs/en/tutorials/first-app/c01-start.mdx +0 -99
  424. package/docs/en/tutorials/first-app/c02-component.mdx +0 -60
  425. package/docs/en/tutorials/first-app/c03-css.mdx +0 -324
  426. package/docs/en/tutorials/first-app/c04-routes.mdx +0 -172
  427. package/docs/en/tutorials/first-app/c05-loader.mdx +0 -87
  428. package/docs/en/tutorials/first-app/c06-model.mdx +0 -278
  429. package/docs/en/tutorials/first-app/c07-container.mdx +0 -281
  430. package/docs/en/tutorials/first-app/c08-entries.mdx +0 -135
  431. package/docs/zh/apis/app/hooks/server/index_.mdx +0 -10
  432. package/docs/zh/apis/app/hooks/src/index_.mdx +0 -39
  433. package/docs/zh/apis/app/hooks/src/stories.mdx +0 -16
  434. package/docs/zh/apis/app/runtime/app/define-config.mdx +0 -67
  435. package/docs/zh/apis/app/runtime/core/bootstrap.mdx +0 -74
  436. package/docs/zh/apis/app/runtime/core/create-app.mdx +0 -35
  437. package/docs/zh/apis/app/runtime/core/use-loader.mdx +0 -89
  438. package/docs/zh/apis/app/runtime/core/use-module-apps.mdx +0 -179
  439. package/docs/zh/apis/app/runtime/core/use-runtime-context.mdx +0 -116
  440. package/docs/zh/apis/app/runtime/model/Provider.mdx +0 -36
  441. package/docs/zh/apis/app/runtime/model/auto-actions.mdx +0 -122
  442. package/docs/zh/apis/app/runtime/model/connect.mdx +0 -143
  443. package/docs/zh/apis/app/runtime/model/create-app.mdx +0 -75
  444. package/docs/zh/apis/app/runtime/model/create-store.mdx +0 -61
  445. package/docs/zh/apis/app/runtime/model/handle-effect.mdx +0 -108
  446. package/docs/zh/apis/app/runtime/model/model_.mdx +0 -201
  447. package/docs/zh/apis/app/runtime/model/use-local-model.mdx +0 -29
  448. package/docs/zh/apis/app/runtime/model/use-model.mdx +0 -89
  449. package/docs/zh/apis/app/runtime/model/use-static-model.mdx +0 -49
  450. package/docs/zh/apis/app/runtime/model/use-store.mdx +0 -26
  451. package/docs/zh/apis/app/runtime/ssr/pre-render.mdx +0 -96
  452. package/docs/zh/apis/app/runtime/web-server/hook.mdx +0 -136
  453. package/docs/zh/apis/app/runtime/web-server/middleware.mdx +0 -114
  454. package/docs/zh/apis/app/runtime/web-server/unstable_middleware.mdx +0 -165
  455. package/docs/zh/components/bff-proxy-path-rewrite.mdx +0 -16
  456. package/docs/zh/components/bff-proxy-principle.mdx +0 -1
  457. package/docs/zh/components/builder.mdx +0 -3
  458. package/docs/zh/components/create-bff-api-app.mdx +0 -25
  459. package/docs/zh/components/custom-router-micro-frontend.mdx +0 -40
  460. package/docs/zh/components/enable-micro-frontend.mdx +0 -30
  461. package/docs/zh/components/enableSwc.mdx +0 -17
  462. package/docs/zh/components/global-proxy-config.mdx +0 -85
  463. package/docs/zh/components/global-proxy.mdx +0 -29
  464. package/docs/zh/components/package-manager.mdx +0 -11
  465. package/docs/zh/components/reduck-notify.mdx +0 -27
  466. package/docs/zh/components/reduck-tip.mdx +0 -8
  467. package/docs/zh/configure/app/auto-load-plugin.mdx +0 -66
  468. package/docs/zh/configure/app/deploy/microFrontend.mdx +0 -55
  469. package/docs/zh/configure/app/dev/port.mdx +0 -25
  470. package/docs/zh/configure/app/dev/proxy.mdx +0 -9
  471. package/docs/zh/configure/app/experiments/lazy-compilation.mdx +0 -105
  472. package/docs/zh/configure/app/html/disable-html-folder.mdx +0 -45
  473. package/docs/zh/configure/app/html/favicon-by-entries.mdx +0 -37
  474. package/docs/zh/configure/app/html/inject-by-entries.mdx +0 -37
  475. package/docs/zh/configure/app/html/meta-by-entries.mdx +0 -48
  476. package/docs/zh/configure/app/html/tags-by-entries.mdx +0 -44
  477. package/docs/zh/configure/app/html/template-by-entries.mdx +0 -33
  478. package/docs/zh/configure/app/html/template-parameters-by-entries.mdx +0 -36
  479. package/docs/zh/configure/app/html/title-by-entries.mdx +0 -37
  480. package/docs/zh/configure/app/output/css-module-local-ident-name.mdx +0 -21
  481. package/docs/zh/configure/app/output/disable-css-extract.mdx +0 -16
  482. package/docs/zh/configure/app/output/disable-filename-hash.mdx +0 -16
  483. package/docs/zh/configure/app/output/disable-minimize.mdx +0 -14
  484. package/docs/zh/configure/app/output/disable-node-polyfill.mdx +0 -22
  485. package/docs/zh/configure/app/output/disable-source-map.mdx +0 -31
  486. package/docs/zh/configure/app/output/enable-asset-fallback.mdx +0 -36
  487. package/docs/zh/configure/app/output/enable-inline-scripts.mdx +0 -22
  488. package/docs/zh/configure/app/output/enable-inline-styles.mdx +0 -22
  489. package/docs/zh/configure/app/output/enable-latest-decorators.mdx +0 -14
  490. package/docs/zh/configure/app/performance/transform-lodash.mdx +0 -52
  491. package/docs/zh/configure/app/runtime/master-app.mdx +0 -38
  492. package/docs/zh/configure/app/runtime/state.mdx +0 -52
  493. package/docs/zh/configure/app/source/disable-entry-dirs.mdx +0 -38
  494. package/docs/zh/configure/app/source/enable-custom-entry.mdx +0 -67
  495. package/docs/zh/configure/app/source/module-scopes.mdx +0 -72
  496. package/docs/zh/configure/app/source/resolve-extension-prefix.mdx +0 -57
  497. package/docs/zh/configure/app/source/resolve-main-fields.mdx +0 -46
  498. package/docs/zh/configure/app/tools/esbuild.mdx +0 -44
  499. package/docs/zh/configure/app/tools/pug.mdx +0 -54
  500. package/docs/zh/configure/app/tools/styled-components.mdx +0 -54
  501. package/docs/zh/configure/app/tools/tailwindcss.mdx +0 -98
  502. package/docs/zh/configure/app/tools/terser.mdx +0 -58
  503. package/docs/zh/configure/app/tools/ts-loader.mdx +0 -76
  504. package/docs/zh/configure/app/tools/webpack-chain.mdx +0 -253
  505. package/docs/zh/configure/app/tools/webpack.mdx +0 -305
  506. package/docs/zh/guides/advanced-features/rspack-start.mdx +0 -154
  507. package/docs/zh/guides/deprecated.md +0 -19
  508. package/docs/zh/guides/topic-detail/micro-frontend/c01-introduction.mdx +0 -26
  509. package/docs/zh/guides/topic-detail/micro-frontend/c02-development.mdx +0 -332
  510. package/docs/zh/guides/topic-detail/micro-frontend/c03-main-app.mdx +0 -296
  511. package/docs/zh/guides/topic-detail/micro-frontend/c04-communicate.mdx +0 -58
  512. package/docs/zh/guides/topic-detail/micro-frontend/c05-mixed-stack.mdx +0 -27
  513. package/docs/zh/guides/topic-detail/model/_meta.json +0 -14
  514. package/docs/zh/guides/topic-detail/model/auto-actions.mdx +0 -88
  515. package/docs/zh/guides/topic-detail/model/computed-state.mdx +0 -147
  516. package/docs/zh/guides/topic-detail/model/define-model.mdx +0 -63
  517. package/docs/zh/guides/topic-detail/model/faq.mdx +0 -36
  518. package/docs/zh/guides/topic-detail/model/manage-effects.mdx +0 -256
  519. package/docs/zh/guides/topic-detail/model/model-communicate.mdx +0 -217
  520. package/docs/zh/guides/topic-detail/model/performance.mdx +0 -167
  521. package/docs/zh/guides/topic-detail/model/quick-start.mdx +0 -117
  522. package/docs/zh/guides/topic-detail/model/redux-integration.mdx +0 -20
  523. package/docs/zh/guides/topic-detail/model/typescript-best-practice.mdx +0 -67
  524. package/docs/zh/guides/topic-detail/model/use-model.mdx +0 -248
  525. package/docs/zh/guides/topic-detail/model/use-out-of-modernjs.mdx +0 -46
  526. package/docs/zh/plugin/official/cli-plugins/plugin-swc.mdx +0 -351
  527. package/docs/zh/plugin/official/cli-plugins/plugin-tailwind.mdx +0 -5
  528. package/docs/zh/plugin/official/rsbuild-plugins/_meta.json +0 -1
  529. package/docs/zh/plugin/official/rsbuild-plugins/plugin-esbuild.mdx +0 -201
  530. package/docs/zh/plugin/official/rsbuild-plugins.mdx +0 -3
  531. package/docs/zh/tutorials/first-app/c01-start.mdx +0 -99
  532. package/docs/zh/tutorials/first-app/c02-component.mdx +0 -60
  533. package/docs/zh/tutorials/first-app/c03-css.mdx +0 -323
  534. package/docs/zh/tutorials/first-app/c04-routes.mdx +0 -172
  535. package/docs/zh/tutorials/first-app/c05-loader.mdx +0 -89
  536. package/docs/zh/tutorials/first-app/c06-model.mdx +0 -274
  537. package/docs/zh/tutorials/first-app/c07-container.mdx +0 -281
  538. package/docs/zh/tutorials/first-app/c08-entries.mdx +0 -135
  539. /package/docs/en/components/{reduck-migration.mdx → auto-upgrade.mdx} +0 -0
  540. /package/docs/{zh/components/reduck-migration.mdx → en/components/international/platform-support.mdx} +0 -0
@@ -0,0 +1,417 @@
1
+ ---
2
+ title: 资源加载
3
+ ---
4
+
5
+ # 资源加载
6
+
7
+ 插件支持三种资源加载方式:HTTP 后端、文件系统后端(FS Backend)和 SDK 后端。同时,插件还支持链式后端,可以组合使用多个后端。
8
+
9
+ ## HTTP 后端
10
+
11
+ HTTP 后端通过 HTTP 请求加载资源文件,适用于客户端渲染(CSR)场景。
12
+
13
+ ### 配置方式
14
+
15
+ ```ts
16
+ i18nPlugin({
17
+ backend: {
18
+ enabled: true,
19
+ loadPath: '/locales/{{lng}}/{{ns}}.json',
20
+ },
21
+ });
22
+ ```
23
+
24
+ ### 资源文件结构
25
+
26
+ 资源文件需要放在 `config/public` 目录或通过 `server.publicDir` 配置的目录中:
27
+
28
+ ```
29
+ config/public/
30
+ └── locales/
31
+ ├── en/
32
+ │ └── translation.json
33
+ └── zh/
34
+ └── translation.json
35
+ ```
36
+
37
+ 或者通过 `server.publicDir` 配置自定义目录:
38
+
39
+ ```ts
40
+ export default defineConfig({
41
+ server: {
42
+ publicDir: './locales', // 指定资源文件目录
43
+ },
44
+ plugins: [
45
+ i18nPlugin({
46
+ backend: {
47
+ enabled: true,
48
+ loadPath: '/locales/{{lng}}/{{ns}}.json',
49
+ },
50
+ }),
51
+ ],
52
+ });
53
+ ```
54
+
55
+ **资源文件格式**:
56
+
57
+ ```json
58
+ {
59
+ "key1": "value1",
60
+ "key2": "value2",
61
+ "nested": {
62
+ "key": "value"
63
+ }
64
+ }
65
+ ```
66
+
67
+ ### 路径变量
68
+
69
+ `loadPath` 支持以下变量:
70
+
71
+ - `{{lng}}`:语言代码(如 `en`、`zh`)
72
+ - `{{ns}}`:命名空间(如 `translation`、`common`)
73
+
74
+ **示例**:
75
+
76
+ ```ts
77
+ // 默认路径格式
78
+ loadPath: '/locales/{{lng}}/{{ns}}.json';
79
+ // 实际加载路径:
80
+ // /locales/en/translation.json
81
+ // /locales/zh/translation.json
82
+
83
+ // 自定义路径格式
84
+ loadPath: '/i18n/{{lng}}/{{ns}}.json';
85
+ // 实际加载路径:
86
+ // /i18n/en/translation.json
87
+ // /i18n/zh/translation.json
88
+ ```
89
+
90
+ ## 文件系统后端(FS Backend)
91
+
92
+ 文件系统后端直接从文件系统读取资源文件,适用于服务端渲染(SSR)场景。
93
+
94
+ ### 配置方式
95
+
96
+ 在 SSR 场景下,插件会自动使用文件系统后端。资源文件需要放在项目目录中:
97
+
98
+ ```
99
+ 项目根目录/
100
+ └── locales/
101
+ ├── en/
102
+ │ └── translation.json
103
+ └── zh/
104
+ └── translation.json
105
+ ```
106
+
107
+ ### 资源文件路径
108
+
109
+ 文件系统后端的默认路径格式为相对路径:
110
+
111
+ ```
112
+ ./locales/{{lng}}/{{ns}}.json
113
+ ```
114
+
115
+ 可以通过 `loadPath` 自定义路径:
116
+
117
+ ```ts
118
+ i18nPlugin({
119
+ backend: {
120
+ enabled: true,
121
+ loadPath: '/locales/{{lng}}/{{ns}}.json', // 使用绝对路径(推荐)
122
+ },
123
+ });
124
+ ```
125
+
126
+ :::warning
127
+ `loadPath` 配置会同时用于 HTTP 后端(前端)和文件系统后端(服务端)。如果配置的是以 `/` 开头的绝对路径(如 `/locales/{{lng}}/{{ns}}.json`),文件系统后端会自动将其转换为相对路径(`./locales/{{lng}}/{{ns}}.json`)。因此,建议在配置中使用绝对路径,这样可以同时满足前后端的需求。
128
+
129
+ :::
130
+
131
+ ## SDK 后端
132
+
133
+ SDK 后端允许通过自定义函数加载资源,适用于需要从外部服务、数据库或其他自定义来源加载翻译资源的场景。
134
+
135
+ ### 启用 SDK 模式
136
+
137
+ **步骤 1:在 `modern.config.ts` 中启用 SDK 模式**
138
+
139
+ ```ts
140
+ i18nPlugin({
141
+ backend: {
142
+ enabled: true,
143
+ sdk: true, // 启用 SDK 模式
144
+ },
145
+ });
146
+ ```
147
+
148
+ **步骤 2:在 `modern.runtime.ts` 中实现 SDK 函数**
149
+
150
+ ```ts
151
+ import { defineRuntimeConfig } from '@modern-js/runtime';
152
+ import type { I18nSdkLoader, Resources } from '@modern-js/plugin-i18n/runtime';
153
+
154
+ const mySdkLoader: I18nSdkLoader = async options => {
155
+ // 实现资源加载逻辑
156
+ if (options.all) {
157
+ // 加载所有资源
158
+ return await loadAllResources();
159
+ }
160
+
161
+ if (options.lng && options.ns) {
162
+ // 加载单个资源
163
+ return await loadSingleResource(options.lng, options.ns);
164
+ }
165
+
166
+ return {};
167
+ };
168
+
169
+ export default defineRuntimeConfig({
170
+ i18n: {
171
+ initOptions: {
172
+ backend: {
173
+ sdk: mySdkLoader,
174
+ },
175
+ },
176
+ },
177
+ });
178
+ ```
179
+
180
+ ### 实现 SDK 加载函数
181
+
182
+ SDK 函数接收一个 `I18nSdkLoadOptions` 参数,需要返回 `Resources` 格式的数据:
183
+
184
+ ```ts
185
+ interface I18nSdkLoadOptions {
186
+ /** 单个语言代码 */
187
+ lng?: string;
188
+ /** 单个命名空间 */
189
+ ns?: string;
190
+ /** 多个语言代码 */
191
+ lngs?: string[];
192
+ /** 多个命名空间 */
193
+ nss?: string[];
194
+ /** 加载所有资源 */
195
+ all?: boolean;
196
+ }
197
+
198
+ type Resources = {
199
+ [lng: string]: {
200
+ [ns: string]: Record<string, string>;
201
+ };
202
+ };
203
+ ```
204
+
205
+ ### 批量加载示例
206
+
207
+ SDK 后端支持多种加载模式:
208
+
209
+ **1. 加载单个资源**:
210
+
211
+ ```ts
212
+ const sdkLoader: I18nSdkLoader = async options => {
213
+ if (options.lng && options.ns) {
214
+ const response = await fetch(`/api/i18n/${options.lng}/${options.ns}`);
215
+ const data = await response.json();
216
+ return {
217
+ [options.lng]: {
218
+ [options.ns]: data,
219
+ },
220
+ };
221
+ }
222
+ return {};
223
+ };
224
+ ```
225
+
226
+ **2. 批量加载多个语言**:
227
+
228
+ ```ts
229
+ const sdkLoader: I18nSdkLoader = async options => {
230
+ if (options.lngs && options.ns) {
231
+ const resources: Resources = {};
232
+ for (const lng of options.lngs) {
233
+ const response = await fetch(`/api/i18n/${lng}/${options.ns}`);
234
+ resources[lng] = {
235
+ [options.ns]: await response.json(),
236
+ };
237
+ }
238
+ return resources;
239
+ }
240
+ return {};
241
+ };
242
+ ```
243
+
244
+ **3. 批量加载多个命名空间**:
245
+
246
+ ```ts
247
+ const sdkLoader: I18nSdkLoader = async options => {
248
+ if (options.lng && options.nss) {
249
+ const resources: Resources = {
250
+ [options.lng]: {},
251
+ };
252
+ for (const ns of options.nss) {
253
+ const response = await fetch(`/api/i18n/${options.lng}/${ns}`);
254
+ resources[options.lng][ns] = await response.json();
255
+ }
256
+ return resources;
257
+ }
258
+ return {};
259
+ };
260
+ ```
261
+
262
+ **4. 加载所有资源**:
263
+
264
+ ```ts
265
+ const sdkLoader: I18nSdkLoader = async options => {
266
+ if (options.all) {
267
+ const response = await fetch('/api/i18n/all');
268
+ return await response.json();
269
+ }
270
+ return {};
271
+ };
272
+ ```
273
+
274
+ ### 检查资源加载状态
275
+
276
+ 使用 SDK 后端时,可以使用 `isResourcesReady` 检查资源是否已加载:
277
+
278
+ ```tsx
279
+ import { useModernI18n } from '@modern-js/plugin-i18n/runtime';
280
+
281
+ function MyComponent() {
282
+ const { isResourcesReady } = useModernI18n();
283
+
284
+ if (!isResourcesReady) {
285
+ return <div>正在加载翻译资源...</div>;
286
+ }
287
+
288
+ return <div>资源已准备好!</div>;
289
+ }
290
+ ```
291
+
292
+ 这在资源异步加载时特别有用,因为它确保当前语言的所有必需命名空间都已加载完成,然后再渲染依赖翻译的内容。
293
+
294
+ ## 链式后端(Chained Backend)
295
+
296
+ 链式后端允许同时使用多个后端,实现资源的渐进式加载和更新。当同时配置 `loadPath`(或 FS 后端)和 `sdk` 时,插件会自动使用 `i18next-chained-backend` 来链式加载资源。
297
+
298
+ ### 工作原理
299
+
300
+ 链式后端的工作流程:
301
+
302
+ 1. **初始加载**:首先从 HTTP/FS 后端加载资源并立即显示(快速显示基础翻译)
303
+ 2. **异步更新**:然后从 SDK 后端异步加载资源并更新 i18next store(更新/补充翻译)
304
+
305
+ 这样可以确保用户快速看到页面内容,同时后台加载最新的翻译资源。
306
+
307
+ ### 配置方式
308
+
309
+ **步骤 1:在 `modern.config.ts` 中配置链式后端**
310
+
311
+ ```ts
312
+ i18nPlugin({
313
+ backend: {
314
+ enabled: true,
315
+ loadPath: '/locales/{{lng}}/{{ns}}.json', // HTTP/FS 后端
316
+ sdk: true, // SDK 后端
317
+ // cacheHitMode: 'refreshAndUpdateStore', // 默认值,可省略
318
+ },
319
+ });
320
+ ```
321
+
322
+ **步骤 2:在 `modern.runtime.ts` 中实现 SDK 函数**
323
+
324
+ ```ts
325
+ import { defineRuntimeConfig } from '@modern-js/runtime';
326
+
327
+ export default defineRuntimeConfig({
328
+ i18n: {
329
+ initOptions: {
330
+ backend: {
331
+ sdk: async options => {
332
+ // SDK 实现
333
+ if (options.lng && options.ns) {
334
+ return await mySdk.getResource(options.lng, options.ns);
335
+ }
336
+ },
337
+ },
338
+ },
339
+ },
340
+ });
341
+ ```
342
+
343
+ ### 缓存命中模式(cacheHitMode)
344
+
345
+ `cacheHitMode` 选项控制链式后端的行为:
346
+
347
+ - **`'none'`**(默认,仅当未配置链式后端时):如果第一个后端返回了资源,则停止,不再尝试下一个后端
348
+ - **`'refresh'`**:尝试从下一个后端刷新缓存并更新缓存
349
+ - **`'refreshAndUpdateStore'`**(链式后端的默认值):尝试从下一个后端刷新缓存,更新缓存并同时更新 i18next 资源存储。这允许先显示 FS/HTTP 资源,然后 SDK 资源会异步更新它们。
350
+
351
+ **配置示例**:
352
+
353
+ ```ts
354
+ i18nPlugin({
355
+ backend: {
356
+ enabled: true,
357
+ loadPath: '/locales/{{lng}}/{{ns}}.json',
358
+ sdk: true,
359
+ cacheHitMode: 'refreshAndUpdateStore', // 显式指定(默认值)
360
+ },
361
+ });
362
+ ```
363
+
364
+ ### 使用场景
365
+
366
+ 链式后端特别适用于以下场景:
367
+
368
+ 1. **渐进式加载**:先显示本地/静态资源,然后从远程服务加载最新翻译
369
+ 2. **离线支持**:本地资源作为离线 fallback,SDK 资源提供在线更新
370
+ 3. **性能优化**:快速显示基础翻译,后台加载完整翻译内容
371
+ 4. **A/B 测试**:本地资源作为默认值,SDK 提供动态翻译变体
372
+
373
+ ### 完整示例
374
+
375
+ ```ts
376
+ // modern.config.ts
377
+ i18nPlugin({
378
+ backend: {
379
+ enabled: true,
380
+ loadPath: '/locales/{{lng}}/{{ns}}.json', // 本地资源
381
+ sdk: true, // 远程 SDK 资源
382
+ cacheHitMode: 'refreshAndUpdateStore',
383
+ },
384
+ });
385
+
386
+ // modern.runtime.ts
387
+ import { defineRuntimeConfig } from '@modern-js/runtime';
388
+
389
+ export default defineRuntimeConfig({
390
+ i18n: {
391
+ initOptions: {
392
+ backend: {
393
+ sdk: async options => {
394
+ if (options.lng && options.ns) {
395
+ // 从远程服务加载最新翻译
396
+ const response = await fetch(
397
+ `https://api.example.com/i18n/${options.lng}/${options.ns}`,
398
+ );
399
+ return {
400
+ [options.lng]: {
401
+ [options.ns]: await response.json(),
402
+ },
403
+ };
404
+ }
405
+ return {};
406
+ },
407
+ },
408
+ },
409
+ },
410
+ });
411
+ ```
412
+
413
+ 在这个示例中:
414
+
415
+ - 页面加载时,首先从 `/locales/{{lng}}/{{ns}}.json` 加载资源并立即显示
416
+ - 后台异步从 `https://api.example.com/i18n/...` 加载最新翻译
417
+ - SDK 资源加载完成后,自动更新 i18next store,界面文案自动更新
@@ -0,0 +1,212 @@
1
+ ---
2
+ title: 路由集成
3
+ ---
4
+
5
+ # 路由集成
6
+
7
+ 插件与 Modern.js 路由系统深度集成,支持语言路径前缀和自动路径重定向。
8
+
9
+ ## 启用路径重定向
10
+
11
+ 当 `localePathRedirect` 设置为 `true` 时,插件会自动在 URL 中添加语言前缀,并处理语言切换时的路径重定向。
12
+
13
+ **配置**:
14
+
15
+ ```ts
16
+ i18nPlugin({
17
+ localeDetection: {
18
+ localePathRedirect: true,
19
+ languages: ['zh', 'en'],
20
+ fallbackLanguage: 'en',
21
+ // 可选:忽略某些路由的自动重定向
22
+ ignoreRedirectRoutes: ['/api', '/admin'],
23
+ },
24
+ });
25
+ ```
26
+
27
+ ### 忽略重定向的路由
28
+
29
+ 某些路由(如 API 路由、静态资源等)不需要语言前缀,可以使用 `ignoreRedirectRoutes` 配置来忽略这些路由的自动重定向:
30
+
31
+ ```ts
32
+ i18nPlugin({
33
+ localeDetection: {
34
+ localePathRedirect: true,
35
+ languages: ['zh', 'en'],
36
+ fallbackLanguage: 'en',
37
+ // 字符串数组:支持精确匹配和前缀匹配
38
+ ignoreRedirectRoutes: ['/api', '/admin', '/static'],
39
+ // 或使用函数进行更灵活的判断
40
+ ignoreRedirectRoutes: pathname => {
41
+ return pathname.startsWith('/api') || pathname.startsWith('/admin');
42
+ },
43
+ },
44
+ });
45
+ ```
46
+
47
+ 更多详情请参考[语言检测文档](./locale-detection#ignoreredirectroutes)中的 `ignoreRedirectRoutes` 配置说明。
48
+
49
+ ## 路由配置
50
+
51
+ 启用路径重定向后,需要在路由配置中添加 `:lang` 动态参数。
52
+
53
+ ### 约定式路由
54
+
55
+ 使用约定式路由时,需要在 `routes/` 目录下创建 `[lang]` 目录来表示语言参数:
56
+
57
+ ```bash
58
+ routes/
59
+ ├── [lang]/
60
+ │ ├── layout.tsx # 布局组件
61
+ │ ├── page.tsx # 首页
62
+ │ ├── about/
63
+ │ │ └── page.tsx # About 页面
64
+ │ └── contact/
65
+ │ └── page.tsx # Contact 页面
66
+ ```
67
+
68
+ **routes/[lang]/layout.tsx**:
69
+
70
+ ```tsx
71
+ import { Outlet } from '@modern-js/runtime/router';
72
+
73
+ export default function Layout() {
74
+ return <Outlet />;
75
+ }
76
+ ```
77
+
78
+ **routes/[lang]/page.tsx**:
79
+
80
+ ```tsx
81
+ export default function Home() {
82
+ return <div>Home</div>;
83
+ }
84
+ ```
85
+
86
+ **routes/[lang]/about/page.tsx**:
87
+
88
+ ```tsx
89
+ export default function About() {
90
+ return <div>About</div>;
91
+ }
92
+ ```
93
+
94
+ **routes/[lang]/contact/page.tsx**:
95
+
96
+ ```tsx
97
+ export default function Contact() {
98
+ return <div>Contact</div>;
99
+ }
100
+ ```
101
+
102
+ **生成的路由结构**:
103
+
104
+ ```
105
+ /:lang → Home 页面
106
+ /:lang/about → About 页面
107
+ /:lang/contact → Contact 页面
108
+ ```
109
+
110
+ 访问 `/` 或 `/about` 时,会自动重定向到 `/en` 或 `/en/about`(使用默认语言)。
111
+
112
+ ### 自定义路由
113
+
114
+ 如果使用自定义路由(`modern.routes.ts`),需要在路由配置中添加 `:lang` 动态参数:
115
+
116
+ ```tsx
117
+ import {
118
+ BrowserRouter,
119
+ Route,
120
+ Routes,
121
+ Outlet,
122
+ } from '@modern-js/runtime/router';
123
+
124
+ function App() {
125
+ return (
126
+ <BrowserRouter>
127
+ <Routes>
128
+ {/* 添加 :lang 参数 */}
129
+ <Route path=":lang" element={<Outlet />}>
130
+ <Route index element={<Home />} />
131
+ <Route path="about" element={<About />} />
132
+ <Route path="contact" element={<Contact />} />
133
+ </Route>
134
+ </Routes>
135
+ </BrowserRouter>
136
+ );
137
+ }
138
+ ```
139
+
140
+ :::info
141
+ 约定式路由会自动根据文件结构生成对应的路由,推荐使用约定式路由。只有在需要特殊路由控制时才使用自定义路由。
142
+
143
+ :::
144
+
145
+ ## I18nLink 组件
146
+
147
+ `I18nLink` 组件是 `@modern-js/plugin-i18n` 提供的链接组件,会自动在路径前添加当前语言前缀。
148
+
149
+ ### 基本用法
150
+
151
+ ```tsx
152
+ import { I18nLink } from '@modern-js/plugin-i18n/runtime';
153
+
154
+ function Navigation() {
155
+ return (
156
+ <nav>
157
+ <I18nLink to="/">首页</I18nLink>
158
+ <I18nLink to="/about">关于</I18nLink>
159
+ <I18nLink to="/contact">联系</I18nLink>
160
+ </nav>
161
+ );
162
+ }
163
+ ```
164
+
165
+ **当前语言为 `en` 时**:
166
+
167
+ - `<I18nLink to="/">` → 实际链接:`/en`
168
+ - `<I18nLink to="/about">` → 实际链接:`/en/about`
169
+
170
+ **当前语言为 `zh` 时**:
171
+
172
+ - `<I18nLink to="/">` → 实际链接:`/zh`
173
+ - `<I18nLink to="/about">` → 实际链接:`/zh/about`
174
+
175
+ ### 自动添加语言前缀
176
+
177
+ `I18nLink` 会自动处理语言前缀,无需手动添加:
178
+
179
+ ```tsx
180
+ // ✅ 正确:不需要手动添加语言前缀
181
+ <I18nLink to="/about">关于</I18nLink>
182
+
183
+ // ❌ 错误:不要手动添加语言前缀
184
+ <I18nLink to="/en/about">关于</I18nLink>
185
+ ```
186
+
187
+ ### Props 说明
188
+
189
+ `I18nLink` 接受所有 `Link` 组件的 props,并额外支持:
190
+
191
+ ```tsx
192
+ interface I18nLinkProps {
193
+ /** 目标路径(不需要包含语言前缀) */
194
+ to: string;
195
+ /** 子元素 */
196
+ children: React.ReactNode;
197
+ /** 其他 Link 组件的 props */
198
+ [key: string]: any;
199
+ }
200
+ ```
201
+
202
+ **示例**:
203
+
204
+ ```tsx
205
+ <I18nLink to="/about" replace>
206
+ 关于
207
+ </I18nLink>
208
+
209
+ <I18nLink to="/contact" state={{ from: 'home' }}>
210
+ 联系
211
+ </I18nLink>
212
+ ```
@@ -0,0 +1,36 @@
1
+ ---
2
+ title: 国际化
3
+ ---
4
+
5
+ # 国际化
6
+
7
+ import I18nPluginIntroduce from '@site-docs/components/international/introduce';
8
+
9
+ <I18nPluginIntroduce />
10
+
11
+ ## 核心功能特性
12
+
13
+ - 🌍 **多语言支持**:轻松管理多种语言的翻译资源
14
+ - 🔍 **智能语言检测**:支持从 URL 路径、Cookie、请求头等多种方式自动检测用户语言
15
+ - 📦 **灵活的资源加载**:支持 HTTP、文件系统和自定义 SDK 三种资源加载方式
16
+ - 🛣️ **路由集成**:与 Modern.js 路由系统深度集成,支持语言路径前缀
17
+ - ⚡ **SSR 支持**:完整支持服务端渲染(SSR)场景
18
+ - 🎯 **TypeScript 支持**:完整的 TypeScript 类型定义
19
+
20
+ ## 适用场景
21
+
22
+ - 需要支持多语言的 Web 应用
23
+ - 需要 SEO 友好的多语言路由
24
+ - 需要服务端渲染的多语言应用
25
+ - 需要从外部服务动态加载翻译资源
26
+
27
+ ## 文档导航
28
+
29
+ - [快速开始](./international/quick-start) - 详细的安装和配置指南
30
+ - [配置说明](./international/configuration) - CLI 和运行时配置详解
31
+ - [语言检测](./international/locale-detection) - 多种语言检测方式和优先级
32
+ - [资源加载](./international/resource-loading) - HTTP、FS、SDK 三种后端使用
33
+ - [路由集成](./international/routing) - 路径重定向和 I18nLink 组件
34
+ - [API 参考](./international/api) - 完整的 API 文档和类型定义
35
+ - [高级用法](./international/advanced) - SSR、多入口、自定义实例等
36
+ - [最佳实践](./international/best-practices) - 资源组织、错误处理、类型安全