@modern-js/main-doc 0.0.0-nightly-20240912170717 → 0.0.0-nightly-20240913170631

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 (317) hide show
  1. package/docs/en/apis/app/commands.mdx +0 -16
  2. package/docs/en/community/contributing-guide.mdx +0 -1
  3. package/docs/en/components/builder.mdx +3 -0
  4. package/docs/en/components/bundler.mdx +3 -0
  5. package/docs/en/components/enableSwc.mdx +17 -0
  6. package/docs/en/components/esbuild.mdx +3 -0
  7. package/docs/en/components/micro-frontend.mdx +6 -0
  8. package/docs/en/components/module-federation.mdx +7 -0
  9. package/docs/en/components/nodeVersion.mdx +26 -0
  10. package/docs/en/components/output-asset-prefix-extend.mdx +0 -0
  11. package/docs/en/components/output-polyfill-extend.mdx +1 -0
  12. package/docs/en/components/prerequisites.mdx +1 -1
  13. package/docs/en/components/rsbuild-config-tooltip.mdx +5 -0
  14. package/docs/en/components/rsbuild.mdx +3 -0
  15. package/docs/en/components/rspack.mdx +3 -0
  16. package/docs/en/components/rspackPrecautions.mdx +6 -0
  17. package/docs/en/components/rspackTip.mdx +7 -0
  18. package/docs/en/components/swc.mdx +3 -0
  19. package/docs/en/configure/app/dev/asset-prefix.mdx +12 -2
  20. package/docs/en/configure/app/dev/before-start-url.mdx +14 -2
  21. package/docs/en/configure/app/dev/client.mdx +20 -16
  22. package/docs/en/configure/app/dev/hmr.mdx +8 -2
  23. package/docs/en/configure/app/dev/host.mdx +15 -2
  24. package/docs/en/configure/app/dev/https.mdx +71 -2
  25. package/docs/en/configure/app/dev/live-reload.mdx +3 -15
  26. package/docs/en/configure/app/dev/port.mdx +18 -2
  27. package/docs/en/configure/app/dev/progress-bar.mdx +17 -2
  28. package/docs/en/configure/app/dev/setup-middlewares.mdx +25 -39
  29. package/docs/en/configure/app/dev/start-url.mdx +46 -2
  30. package/docs/en/configure/app/dev/watch-files.mdx +5 -39
  31. package/docs/en/configure/app/dev/write-to-disk.mdx +4 -27
  32. package/docs/en/configure/app/experiments/lazy-compilation.mdx +84 -2
  33. package/docs/en/configure/app/experiments/source-build.mdx +28 -3
  34. package/docs/en/configure/app/html/app-icon.mdx +48 -2
  35. package/docs/en/configure/app/html/crossorigin.mdx +8 -2
  36. package/docs/en/configure/app/html/disable-html-folder.mdx +35 -2
  37. package/docs/en/configure/app/html/favicon-by-entries.mdx +29 -2
  38. package/docs/en/configure/app/html/favicon.mdx +14 -2
  39. package/docs/en/configure/app/html/inject-by-entries.mdx +29 -2
  40. package/docs/en/configure/app/html/inject.mdx +8 -2
  41. package/docs/en/configure/app/html/meta-by-entries.mdx +41 -2
  42. package/docs/en/configure/app/html/meta.mdx +22 -2
  43. package/docs/en/configure/app/html/mount-id.mdx +8 -2
  44. package/docs/en/configure/app/html/script-loading.mdx +8 -2
  45. package/docs/en/configure/app/html/tags-by-entries.mdx +37 -2
  46. package/docs/en/configure/app/html/tags.mdx +13 -2
  47. package/docs/en/configure/app/html/template-by-entries.mdx +26 -2
  48. package/docs/en/configure/app/html/template-parameters-by-entries.mdx +28 -2
  49. package/docs/en/configure/app/html/template-parameters.mdx +31 -2
  50. package/docs/en/configure/app/html/template.mdx +8 -2
  51. package/docs/en/configure/app/html/title-by-entries.mdx +30 -2
  52. package/docs/en/configure/app/html/title.mdx +16 -2
  53. package/docs/en/configure/app/output/asset-prefix.mdx +12 -2
  54. package/docs/en/configure/app/output/assets-retry.mdx +72 -2
  55. package/docs/en/configure/app/output/charset.mdx +8 -2
  56. package/docs/en/configure/app/output/clean-dist-path.mdx +13 -2
  57. package/docs/en/configure/app/output/convert-to-rem.mdx +76 -2
  58. package/docs/en/configure/app/output/copy.mdx +5 -2
  59. package/docs/en/configure/app/output/css-module-local-ident-name.mdx +14 -2
  60. package/docs/en/configure/app/output/css-modules.mdx +46 -2
  61. package/docs/en/configure/app/output/data-uri-limit.mdx +24 -2
  62. package/docs/en/configure/app/output/disable-css-extract.mdx +9 -2
  63. package/docs/en/configure/app/output/disable-css-module-extension.mdx +52 -2
  64. package/docs/en/configure/app/output/disable-filename-hash.mdx +9 -2
  65. package/docs/en/configure/app/output/disable-inline-runtime-chunk.mdx +38 -2
  66. package/docs/en/configure/app/output/disable-minimize.mdx +7 -2
  67. package/docs/en/configure/app/output/disable-source-map.mdx +24 -2
  68. package/docs/en/configure/app/output/disable-svgr.mdx +13 -2
  69. package/docs/en/configure/app/output/disable-ts-checker.mdx +46 -2
  70. package/docs/en/configure/app/output/dist-path.mdx +39 -2
  71. package/docs/en/configure/app/output/enable-asset-fallback.mdx +29 -2
  72. package/docs/en/configure/app/output/enable-asset-manifest.mdx +33 -2
  73. package/docs/en/configure/app/output/enable-css-module-tsdeclaration.mdx +25 -2
  74. package/docs/en/configure/app/output/enable-inline-scripts.mdx +15 -2
  75. package/docs/en/configure/app/output/enable-inline-styles.mdx +15 -2
  76. package/docs/en/configure/app/output/enable-latest-decorators.mdx +7 -2
  77. package/docs/en/configure/app/output/externals.mdx +18 -2
  78. package/docs/en/configure/app/output/filename-hash.mdx +3 -27
  79. package/docs/en/configure/app/output/filename.mdx +47 -2
  80. package/docs/en/configure/app/output/inject-styles.mdx +15 -0
  81. package/docs/en/configure/app/output/inline-scripts.mdx +34 -0
  82. package/docs/en/configure/app/output/inline-styles.mdx +34 -0
  83. package/docs/en/configure/app/output/legal-comments.mdx +16 -2
  84. package/docs/en/configure/app/output/minify.mdx +27 -0
  85. package/docs/en/configure/app/output/override-browserslist.mdx +18 -2
  86. package/docs/en/configure/app/output/polyfill.mdx +12 -2
  87. package/docs/en/configure/app/output/source-map.mdx +30 -0
  88. package/docs/en/configure/app/output/ssg.mdx +20 -17
  89. package/docs/en/configure/app/output/svg-default-export.mdx +27 -2
  90. package/docs/en/configure/app/performance/build-cache.mdx +78 -2
  91. package/docs/en/configure/app/performance/bundle-analyze.mdx +18 -2
  92. package/docs/en/configure/app/performance/chunk-split.mdx +38 -2
  93. package/docs/en/configure/app/performance/dns-prefetch.mdx +13 -2
  94. package/docs/en/configure/app/performance/preconnect.mdx +14 -2
  95. package/docs/en/configure/app/performance/prefetch.mdx +19 -2
  96. package/docs/en/configure/app/performance/preload.mdx +21 -2
  97. package/docs/en/configure/app/performance/print-file-size.mdx +38 -2
  98. package/docs/en/configure/app/performance/profile.mdx +8 -2
  99. package/docs/en/configure/app/performance/remove-console.mdx +8 -2
  100. package/docs/en/configure/app/performance/remove-moment-locale.mdx +8 -2
  101. package/docs/en/configure/app/performance/transform-lodash.mdx +42 -2
  102. package/docs/en/configure/app/plugins.mdx +1 -1
  103. package/docs/en/configure/app/security/check-syntax.mdx +66 -2
  104. package/docs/en/configure/app/security/nonce.mdx +13 -2
  105. package/docs/en/configure/app/security/sri.mdx +19 -2
  106. package/docs/en/configure/app/server/port.mdx +5 -0
  107. package/docs/en/configure/app/server/ssr.mdx +10 -9
  108. package/docs/en/configure/app/source/alias-strategy.mdx +8 -2
  109. package/docs/en/configure/app/source/alias.mdx +17 -2
  110. package/docs/en/configure/app/source/config-dir.mdx +1 -1
  111. package/docs/en/configure/app/source/decorators.mdx +8 -21
  112. package/docs/en/configure/app/source/define.mdx +14 -2
  113. package/docs/en/configure/app/source/enable-async-entry.mdx +1 -1
  114. package/docs/en/configure/app/source/entries-dir.mdx +1 -1
  115. package/docs/en/configure/app/source/exclude.mdx +8 -2
  116. package/docs/en/configure/app/source/global-vars.mdx +103 -2
  117. package/docs/en/configure/app/source/include.mdx +19 -2
  118. package/docs/en/configure/app/source/mainEntryName.mdx +1 -1
  119. package/docs/en/configure/app/source/module-scopes.mdx +62 -2
  120. package/docs/en/configure/app/source/pre-entry.mdx +8 -2
  121. package/docs/en/configure/app/source/resolve-extension-prefix.mdx +48 -2
  122. package/docs/en/configure/app/source/resolve-main-fields.mdx +39 -2
  123. package/docs/en/configure/app/source/transform-import.mdx +56 -2
  124. package/docs/en/configure/app/tools/autoprefixer.mdx +41 -2
  125. package/docs/en/configure/app/tools/babel.mdx +218 -2
  126. package/docs/en/configure/app/tools/bundler-chain.mdx +23 -2
  127. package/docs/en/configure/app/tools/css-extract.mdx +31 -2
  128. package/docs/en/configure/app/tools/css-loader.mdx +14 -2
  129. package/docs/en/configure/app/tools/dev-server.mdx +435 -2
  130. package/docs/en/configure/app/tools/esbuild.mdx +1 -1
  131. package/docs/en/configure/app/tools/html-plugin.mdx +21 -2
  132. package/docs/en/configure/app/tools/less.mdx +78 -2
  133. package/docs/en/configure/app/tools/minify-css.mdx +50 -2
  134. package/docs/en/configure/app/tools/postcss.mdx +30 -2
  135. package/docs/en/configure/app/tools/pug.mdx +47 -2
  136. package/docs/en/configure/app/tools/rspack.mdx +8 -2
  137. package/docs/en/configure/app/tools/sass.mdx +75 -2
  138. package/docs/en/configure/app/tools/style-loader.mdx +8 -2
  139. package/docs/en/configure/app/tools/styled-components.mdx +48 -2
  140. package/docs/en/configure/app/tools/swc.mdx +2 -2
  141. package/docs/en/configure/app/tools/terser.mdx +49 -2
  142. package/docs/en/configure/app/tools/ts-checker.mdx +49 -2
  143. package/docs/en/configure/app/tools/ts-loader.mdx +63 -2
  144. package/docs/en/configure/app/tools/webpack-chain.mdx +239 -2
  145. package/docs/en/configure/app/tools/webpack.mdx +295 -2
  146. package/docs/en/guides/advanced-features/_meta.json +0 -1
  147. package/docs/en/guides/advanced-features/rspack-start.mdx +2 -2
  148. package/docs/en/guides/basic-features/css/css-modules.mdx +2 -2
  149. package/docs/en/guides/basic-features/output-files.mdx +1 -1
  150. package/docs/en/guides/basic-features/render/ssg.mdx +1 -1
  151. package/docs/en/guides/concept/builder.mdx +1 -1
  152. package/docs/en/guides/get-started/glossary.mdx +7 -7
  153. package/docs/en/guides/get-started/quick-start.mdx +1 -1
  154. package/docs/en/guides/topic-detail/micro-frontend/c01-introduction.mdx +1 -1
  155. package/docs/en/guides/troubleshooting/builder.mdx +2 -2
  156. package/docs/en/plugin/cli-plugins/plugin-swc.mdx +4 -4
  157. package/docs/en/plugin/rsbuild-plugins/plugin-esbuild.mdx +4 -4
  158. package/docs/zh/apis/app/commands.mdx +0 -18
  159. package/docs/zh/community/contributing-guide.mdx +0 -1
  160. package/docs/zh/components/builder.mdx +3 -0
  161. package/docs/zh/components/bundler.mdx +4 -0
  162. package/docs/zh/components/enableSwc.mdx +17 -0
  163. package/docs/zh/components/esbuild.mdx +3 -0
  164. package/docs/zh/components/micro-frontend.mdx +6 -0
  165. package/docs/zh/components/module-federation.mdx +7 -0
  166. package/docs/zh/components/nodeVersion.mdx +28 -0
  167. package/docs/zh/components/output-asset-prefix-extend.mdx +0 -0
  168. package/docs/zh/components/output-polyfill-extend.mdx +1 -0
  169. package/docs/zh/components/prerequisites.mdx +1 -1
  170. package/docs/zh/components/rsbuild-config-tooltip.mdx +5 -0
  171. package/docs/zh/components/rsbuild.mdx +3 -0
  172. package/docs/zh/components/rspack.mdx +3 -0
  173. package/docs/zh/components/rspackPrecautions.mdx +6 -0
  174. package/docs/zh/components/rspackTip.mdx +7 -0
  175. package/docs/zh/components/swc.mdx +3 -0
  176. package/docs/zh/configure/app/dev/asset-prefix.mdx +12 -2
  177. package/docs/zh/configure/app/dev/before-start-url.mdx +14 -2
  178. package/docs/zh/configure/app/dev/client.mdx +20 -16
  179. package/docs/zh/configure/app/dev/hmr.mdx +8 -2
  180. package/docs/zh/configure/app/dev/host.mdx +15 -2
  181. package/docs/zh/configure/app/dev/https.mdx +72 -2
  182. package/docs/zh/configure/app/dev/live-reload.mdx +3 -15
  183. package/docs/zh/configure/app/dev/port.mdx +18 -2
  184. package/docs/zh/configure/app/dev/progress-bar.mdx +17 -2
  185. package/docs/zh/configure/app/dev/setup-middlewares.mdx +26 -39
  186. package/docs/zh/configure/app/dev/start-url.mdx +47 -2
  187. package/docs/zh/configure/app/dev/watch-files.mdx +5 -39
  188. package/docs/zh/configure/app/dev/write-to-disk.mdx +3 -26
  189. package/docs/zh/configure/app/experiments/lazy-compilation.mdx +84 -2
  190. package/docs/zh/configure/app/experiments/source-build.mdx +29 -2
  191. package/docs/zh/configure/app/html/app-icon.mdx +48 -2
  192. package/docs/zh/configure/app/html/crossorigin.mdx +9 -2
  193. package/docs/zh/configure/app/html/disable-html-folder.mdx +34 -2
  194. package/docs/zh/configure/app/html/favicon-by-entries.mdx +30 -2
  195. package/docs/zh/configure/app/html/favicon.mdx +15 -2
  196. package/docs/zh/configure/app/html/inject-by-entries.mdx +30 -2
  197. package/docs/zh/configure/app/html/inject.mdx +8 -2
  198. package/docs/zh/configure/app/html/meta-by-entries.mdx +41 -2
  199. package/docs/zh/configure/app/html/meta.mdx +22 -2
  200. package/docs/zh/configure/app/html/mount-id.mdx +8 -2
  201. package/docs/zh/configure/app/html/script-loading.mdx +8 -2
  202. package/docs/zh/configure/app/html/tags-by-entries.mdx +37 -2
  203. package/docs/zh/configure/app/html/tags.mdx +13 -2
  204. package/docs/zh/configure/app/html/template-by-entries.mdx +26 -2
  205. package/docs/zh/configure/app/html/template-parameters-by-entries.mdx +29 -2
  206. package/docs/zh/configure/app/html/template-parameters.mdx +31 -2
  207. package/docs/zh/configure/app/html/template.mdx +8 -2
  208. package/docs/zh/configure/app/html/title-by-entries.mdx +30 -2
  209. package/docs/zh/configure/app/html/title.mdx +16 -2
  210. package/docs/zh/configure/app/output/asset-prefix.mdx +12 -2
  211. package/docs/zh/configure/app/output/assets-retry.mdx +72 -2
  212. package/docs/zh/configure/app/output/charset.mdx +8 -2
  213. package/docs/zh/configure/app/output/clean-dist-path.mdx +13 -2
  214. package/docs/zh/configure/app/output/convert-to-rem.mdx +77 -2
  215. package/docs/zh/configure/app/output/copy.mdx +6 -2
  216. package/docs/zh/configure/app/output/css-module-local-ident-name.mdx +14 -2
  217. package/docs/zh/configure/app/output/css-modules.mdx +46 -2
  218. package/docs/zh/configure/app/output/data-uri-limit.mdx +24 -2
  219. package/docs/zh/configure/app/output/disable-css-extract.mdx +9 -2
  220. package/docs/zh/configure/app/output/disable-css-module-extension.mdx +52 -2
  221. package/docs/zh/configure/app/output/disable-filename-hash.mdx +9 -2
  222. package/docs/zh/configure/app/output/disable-inline-runtime-chunk.mdx +38 -2
  223. package/docs/zh/configure/app/output/disable-minimize.mdx +7 -2
  224. package/docs/zh/configure/app/output/disable-source-map.mdx +24 -2
  225. package/docs/zh/configure/app/output/disable-svgr.mdx +14 -2
  226. package/docs/zh/configure/app/output/disable-ts-checker.mdx +46 -2
  227. package/docs/zh/configure/app/output/dist-path.mdx +39 -2
  228. package/docs/zh/configure/app/output/enable-asset-fallback.mdx +29 -2
  229. package/docs/zh/configure/app/output/enable-asset-manifest.mdx +33 -2
  230. package/docs/zh/configure/app/output/enable-css-module-tsdeclaration.mdx +25 -2
  231. package/docs/zh/configure/app/output/enable-inline-scripts.mdx +15 -2
  232. package/docs/zh/configure/app/output/enable-inline-styles.mdx +15 -2
  233. package/docs/zh/configure/app/output/enable-latest-decorators.mdx +7 -2
  234. package/docs/zh/configure/app/output/externals.mdx +18 -2
  235. package/docs/zh/configure/app/output/filename-hash.mdx +4 -27
  236. package/docs/zh/configure/app/output/filename.mdx +47 -2
  237. package/docs/zh/configure/app/output/inject-styles.mdx +15 -0
  238. package/docs/zh/configure/app/output/inline-scripts.mdx +34 -0
  239. package/docs/zh/configure/app/output/inline-styles.mdx +34 -0
  240. package/docs/zh/configure/app/output/legal-comments.mdx +16 -2
  241. package/docs/zh/configure/app/output/minify.mdx +27 -0
  242. package/docs/zh/configure/app/output/override-browserslist.mdx +20 -2
  243. package/docs/zh/configure/app/output/polyfill.mdx +12 -2
  244. package/docs/zh/configure/app/output/source-map.mdx +30 -0
  245. package/docs/zh/configure/app/output/ssg.mdx +19 -15
  246. package/docs/zh/configure/app/output/svg-default-export.mdx +27 -2
  247. package/docs/zh/configure/app/performance/build-cache.mdx +77 -2
  248. package/docs/zh/configure/app/performance/bundle-analyze.mdx +18 -2
  249. package/docs/zh/configure/app/performance/chunk-split.mdx +38 -2
  250. package/docs/zh/configure/app/performance/dns-prefetch.mdx +13 -2
  251. package/docs/zh/configure/app/performance/preconnect.mdx +14 -2
  252. package/docs/zh/configure/app/performance/prefetch.mdx +19 -2
  253. package/docs/zh/configure/app/performance/preload.mdx +21 -2
  254. package/docs/zh/configure/app/performance/print-file-size.mdx +38 -2
  255. package/docs/zh/configure/app/performance/profile.mdx +8 -2
  256. package/docs/zh/configure/app/performance/remove-console.mdx +8 -2
  257. package/docs/zh/configure/app/performance/remove-moment-locale.mdx +8 -2
  258. package/docs/zh/configure/app/performance/transform-lodash.mdx +42 -2
  259. package/docs/zh/configure/app/plugins.mdx +1 -1
  260. package/docs/zh/configure/app/security/check-syntax.mdx +66 -2
  261. package/docs/zh/configure/app/security/nonce.mdx +13 -2
  262. package/docs/zh/configure/app/security/sri.mdx +19 -2
  263. package/docs/zh/configure/app/server/port.mdx +5 -0
  264. package/docs/zh/configure/app/server/ssr.mdx +10 -9
  265. package/docs/zh/configure/app/source/alias-strategy.mdx +8 -2
  266. package/docs/zh/configure/app/source/alias.mdx +17 -2
  267. package/docs/zh/configure/app/source/config-dir.mdx +1 -1
  268. package/docs/zh/configure/app/source/decorators.mdx +8 -20
  269. package/docs/zh/configure/app/source/define.mdx +14 -2
  270. package/docs/zh/configure/app/source/enable-async-entry.mdx +1 -1
  271. package/docs/zh/configure/app/source/entries-dir.mdx +1 -1
  272. package/docs/zh/configure/app/source/exclude.mdx +8 -2
  273. package/docs/zh/configure/app/source/global-vars.mdx +102 -2
  274. package/docs/zh/configure/app/source/include.mdx +19 -2
  275. package/docs/zh/configure/app/source/mainEntryName.mdx +1 -1
  276. package/docs/zh/configure/app/source/module-scopes.mdx +62 -2
  277. package/docs/zh/configure/app/source/pre-entry.mdx +8 -2
  278. package/docs/zh/configure/app/source/resolve-extension-prefix.mdx +50 -2
  279. package/docs/zh/configure/app/source/resolve-main-fields.mdx +39 -2
  280. package/docs/zh/configure/app/source/transform-import.mdx +56 -2
  281. package/docs/zh/configure/app/tools/autoprefixer.mdx +41 -2
  282. package/docs/zh/configure/app/tools/babel.mdx +218 -2
  283. package/docs/zh/configure/app/tools/bundler-chain.mdx +26 -2
  284. package/docs/zh/configure/app/tools/css-extract.mdx +28 -2
  285. package/docs/zh/configure/app/tools/css-loader.mdx +15 -2
  286. package/docs/zh/configure/app/tools/dev-server.mdx +435 -2
  287. package/docs/zh/configure/app/tools/esbuild.mdx +1 -1
  288. package/docs/zh/configure/app/tools/html-plugin.mdx +21 -2
  289. package/docs/zh/configure/app/tools/less.mdx +79 -2
  290. package/docs/zh/configure/app/tools/minify-css.mdx +50 -2
  291. package/docs/zh/configure/app/tools/postcss.mdx +31 -2
  292. package/docs/zh/configure/app/tools/pug.mdx +47 -2
  293. package/docs/zh/configure/app/tools/rspack.mdx +8 -2
  294. package/docs/zh/configure/app/tools/sass.mdx +73 -2
  295. package/docs/zh/configure/app/tools/style-loader.mdx +8 -2
  296. package/docs/zh/configure/app/tools/styled-components.mdx +47 -2
  297. package/docs/zh/configure/app/tools/swc.mdx +2 -2
  298. package/docs/zh/configure/app/tools/terser.mdx +49 -2
  299. package/docs/zh/configure/app/tools/ts-checker.mdx +49 -2
  300. package/docs/zh/configure/app/tools/ts-loader.mdx +63 -2
  301. package/docs/zh/configure/app/tools/webpack-chain.mdx +243 -2
  302. package/docs/zh/configure/app/tools/webpack.mdx +295 -2
  303. package/docs/zh/guides/advanced-features/_meta.json +0 -1
  304. package/docs/zh/guides/advanced-features/rspack-start.mdx +2 -2
  305. package/docs/zh/guides/basic-features/css/css-modules.mdx +1 -1
  306. package/docs/zh/guides/basic-features/output-files.mdx +2 -2
  307. package/docs/zh/guides/concept/builder.mdx +1 -1
  308. package/docs/zh/guides/get-started/glossary.mdx +7 -7
  309. package/docs/zh/guides/get-started/quick-start.mdx +1 -1
  310. package/docs/zh/guides/topic-detail/micro-frontend/c01-introduction.mdx +1 -1
  311. package/docs/zh/guides/troubleshooting/builder.mdx +2 -2
  312. package/docs/zh/plugin/cli-plugins/plugin-swc.mdx +4 -4
  313. package/docs/zh/plugin/rsbuild-plugins/plugin-esbuild.mdx +6 -6
  314. package/package.json +4 -9
  315. package/src/components/RsbuildLink/index.tsx +19 -0
  316. /package/docs/en/configure/app/output/{splitRouteChunks.mdx → split-route-chunks.mdx} +0 -0
  317. /package/docs/zh/configure/app/output/{splitRouteChunks.mdx → split-route-chunks.mdx} +0 -0
@@ -5,7 +5,7 @@ title: entriesDir
5
5
  # source.entriesDir
6
6
 
7
7
  - **类型:** `string`
8
- - **默认值:** `./src`
8
+ - **默认值:** `'./src'`
9
9
 
10
10
  Modern.js 默认会扫描 `src` 目录来识别页面入口,你可以通过该选项自定义页面入口的识别目录。
11
11
 
@@ -1,9 +1,15 @@
1
1
  ---
2
2
  title: exclude
3
+ configName: source.exclude
3
4
  ---
4
5
 
5
6
  # source.exclude
6
7
 
7
- import Main from '@modern-js/builder-doc/docs/zh/config/source/exclude.md';
8
+ - **类型:** [RuleSetCondition[]](https://rspack.dev/zh/config/module#condition)
9
+ - **默认值:** `[]`
8
10
 
9
- <Main />
11
+ 指定不需要编译的 JavaScript/TypeScript 文件。用法与 Rspack 中的 [Rule.exclude](https://rspack.dev/zh/config/module#ruleexclude) 一致,支持传入字符串或正则表达式来匹配模块的路径。
12
+
13
+ import RsbuildConig from '@site-docs/components/rsbuild-config-tooltip';
14
+
15
+ <RsbuildConig />
@@ -4,6 +4,106 @@ title: globalVars
4
4
 
5
5
  # source.globalVars
6
6
 
7
- import Main from '@modern-js/builder-doc/docs/zh/config/source/globalVars.md';
7
+ - **类型:** `Record<string, JSONValue> | Function`
8
+ - **默认值:**
8
9
 
9
- <Main />
10
+ ```ts
11
+ // Modern.js 默认会添加环境变量 `process.env.NODE_ENV`,因此你不需要手动添加它。
12
+ const defaultGlobalVars = {
13
+ 'process.env.NODE_ENV': process.env.NODE_ENV,
14
+ };
15
+ ```
16
+
17
+ 用于在构建时将类似 `process.env.FOO` 的全局变量表达式替换为指定的值,比如:
18
+
19
+ ```js
20
+ console.log(process.env.NODE_ENV);
21
+
22
+ // ⬇️ Turn into being...
23
+ console.log('development');
24
+ ```
25
+
26
+ ### 示例
27
+
28
+ 在下方示例中,会在代码中注入 `ENABLE_VCONSOLE` 和 `APP_CONTEXT` 两个环境变量:
29
+
30
+ ```js
31
+ export default {
32
+ source: {
33
+ globalVars: {
34
+ ENABLE_VCONSOLE: true,
35
+ APP_CONTEXT: { answer: 42 },
36
+ },
37
+ },
38
+ };
39
+ ```
40
+
41
+ 你可以在代码中直接使用它们:
42
+
43
+ ```js
44
+ if (ENABLE_VCONSOLE) {
45
+ // do something
46
+ }
47
+
48
+ console.log(APP_CONTEXT);
49
+ ```
50
+
51
+ ### 函数用法
52
+
53
+ - **类型:**
54
+
55
+ ```ts
56
+ type GlobalVarsFn = (
57
+ obj: Record<string, JSONValue>,
58
+ utils: { env: NodeEnv; target: BuilderTarget },
59
+ ) => Record<string, JSONValue> | void;
60
+ ```
61
+
62
+ 你可以将 `source.globalVars` 设置为一个函数,从而动态设置一些环境变量的值。
63
+
64
+ 比如,根据当前的构建产物类型进行动态设置:
65
+
66
+ ```js
67
+ export default {
68
+ source: {
69
+ globalVars(obj, { target }) {
70
+ obj['MY_TARGET'] = target === 'node' ? 'server' : 'client';
71
+ },
72
+ },
73
+ };
74
+ ```
75
+
76
+ ### 与 define 的区别
77
+
78
+ `source.globalVars` 是 `source.define` 的一个语法糖,它们之间唯一的区别是,`source.globalVars` 会自动将传入的值进行 JSON 序列化处理,这使得设置全局变量的值更加方便。注意 `globalVars` 的每个值都需要是可以被 JSON 序列化的值。
79
+
80
+ ```js
81
+ export default {
82
+ source: {
83
+ globalVars: {
84
+ 'process.env.BUILD_VERSION': '0.0.1',
85
+ 'import.meta.foo': { bar: 42 },
86
+ 'import.meta.baz': false,
87
+ },
88
+ define: {
89
+ 'process.env.BUILD_VERSION': JSON.stringify('0.0.1'),
90
+ 'import.meta': {
91
+ foo: JSON.stringify({ bar: 42 }),
92
+ baz: JSON.stringify(false),
93
+ },
94
+ },
95
+ },
96
+ };
97
+ ```
98
+
99
+ ### 注意事项
100
+
101
+ `source.globalVars` 是通过字符串替换的形式来注入环境变量的,因此它无法对「解构赋值」等动态写法生效。
102
+
103
+ 在使用解构赋值时,Modern.js 将无法判断变量 `NODE_ENV` 是否与要替换的表达式 `process.env.NODE_ENV` 存在关联,因此以下使用方式是无效的:
104
+
105
+ ```js
106
+ const { NODE_ENV } = process.env;
107
+ console.log(NODE_ENV);
108
+ // ❌ Won't get a string.
109
+ ```
@@ -1,9 +1,26 @@
1
1
  ---
2
2
  title: include
3
+ configName: source.include
3
4
  ---
4
5
 
5
6
  # source.include
6
7
 
7
- import Main from '@modern-js/builder-doc/docs/zh/config/source/include.md';
8
+ - **类型:** [RuleSetCondition[]](https://rspack.dev/zh/config/module#condition)
9
+ - **默认值:**
8
10
 
9
- <Main />
11
+ ```ts
12
+ const defaultInclude = [
13
+ [
14
+ /node_modules\/react-router/,
15
+ /node_modules\/react-router-dom/,
16
+ /node_modules\/@remix-run\/router/,
17
+ '/node_modules/.modern-js',
18
+ ],
19
+ ];
20
+ ```
21
+
22
+ `source.include` 用于指定额外需要编译的 JavaScript 文件。
23
+
24
+ import RsbuildConig from '@site-docs/components/rsbuild-config-tooltip';
25
+
26
+ <RsbuildConig />
@@ -5,7 +5,7 @@ title: mainEntryName
5
5
  # source.mainEntryName
6
6
 
7
7
  - **类型:** `string`
8
- - **默认值:** `main`
8
+ - **默认值:** `'main'`
9
9
 
10
10
  该选项用于配置 Modern.js 的主入口名称。
11
11
 
@@ -4,6 +4,66 @@ title: moduleScopes
4
4
 
5
5
  # source.moduleScopes
6
6
 
7
- import Main from '@modern-js/builder-doc/docs/zh/config/source/moduleScopes.md';
7
+ - **类型:** `Array<string | Regexp> | Function`
8
+ - **默认值:** `undefined`
9
+ - **打包工具:** `仅支持 webpack`
8
10
 
9
- <Main />
11
+ 限制源代码的引用路径。配置该选项后,所有源文件只能从约定的目录下引用代码,从其他目录引用代码会产生对应的报错提示。
12
+
13
+ ### 示例
14
+
15
+ 首先我们配置 `moduleScopes` 仅包含 `src` 目录:
16
+
17
+ ```js
18
+ export default {
19
+ source: {
20
+ moduleScopes: ['./src'],
21
+ },
22
+ };
23
+ ```
24
+
25
+ 然后在 `src/App.tsx` 中导入 `src` 目录外部的 `utils/a` 模块:
26
+
27
+ ```js
28
+ import a from '../utils/a';
29
+ ```
30
+
31
+ 在编译时,会提示引用路径错误:
32
+
33
+ ![scopes-error](https://lf3-static.bytednsdoc.com/obj/eden-cn/aphqeh7uhohpquloj/modern-js/docs/module-scopes-error.png)
34
+
35
+ 通过该选项配置 `utils` 目录,再进行编译,则不会出现错误提示。
36
+
37
+ ```js
38
+ export default {
39
+ source: {
40
+ moduleScopes: ['./src', './utils'],
41
+ },
42
+ };
43
+ ```
44
+
45
+ ### Array 类型
46
+
47
+ 当 `moduleScopes` 的值为 `Array` 类型时,可以直接设置若干个代码路径,比如添加以下配置:
48
+
49
+ ```js
50
+ export default {
51
+ source: {
52
+ moduleScopes: ['./src', './shared', './utils'],
53
+ },
54
+ };
55
+ ```
56
+
57
+ ### Function 类型
58
+
59
+ `moduleScopes` 也支持通过函数的形式来进行修改,避免覆盖默认值:
60
+
61
+ ```js
62
+ export default {
63
+ source: {
64
+ moduleScopes: scopes => {
65
+ scopes.push('./shared');
66
+ },
67
+ },
68
+ };
69
+ ```
@@ -1,9 +1,15 @@
1
1
  ---
2
2
  title: preEntry
3
+ configName: source.preEntry
3
4
  ---
4
5
 
5
6
  # source.preEntry
6
7
 
7
- import Main from '@modern-js/builder-doc/docs/zh/config/source/preEntry.md';
8
+ - **类型:** `string | string[]`
9
+ - **默认值:** `[]`
8
10
 
9
- <Main />
11
+ 在每个页面的入口文件前添加一段代码,这段代码会早于页面的代码执行,因此可以用于执行一些全局的代码逻辑,比如注入 polyfill、设置全局样式等。
12
+
13
+ import RsbuildConig from '@site-docs/components/rsbuild-config-tooltip';
14
+
15
+ <RsbuildConig />
@@ -4,6 +4,54 @@ title: resolveExtensionPrefix
4
4
 
5
5
  # source.resolveExtensionPrefix
6
6
 
7
- import Main from '@modern-js/builder-doc/docs/zh/config/source/resolveExtensionPrefix.md';
7
+ - **类型:** `string | Record<BuilderTarget, string>`
8
+ - **默认值:** `undefined`
8
9
 
9
- <Main />
10
+ 用于为 [resolve.extensions](https://webpack.js.org/configuration/resolve/#resolveextensions) 添加统一的前缀。
11
+
12
+ 如果多个文件拥有相同的名称,但具有不同的文件后缀,Modern.js 会根据 extensions 数组的顺序进行识别,解析数组中第一个被识别的文件,并跳过其余文件。
13
+
14
+ ### 示例
15
+
16
+ 下面是配置 `.web` 前缀的例子。
17
+
18
+ ```js
19
+ export default {
20
+ source: {
21
+ resolveExtensionPrefix: '.web',
22
+ },
23
+ };
24
+ ```
25
+
26
+ 配置完成后,extensions 数组会发生以下变化:
27
+
28
+ ```js
29
+ // 配置前
30
+ const extensions = ['.js', '.ts', ...];
31
+
32
+ // 配置后
33
+ const extensions = ['.web.js', '.js', '.web.ts' , '.ts', ...];
34
+ ```
35
+
36
+ 在代码中 `import './foo'` 时,会优先识别 `foo.web.js` 文件,再识别 `foo.js` 文件。
37
+
38
+ #### 根据产物类型设置
39
+
40
+ 当你同时构建多种类型的产物时,你可以为不同的产物类型设置不同的 extension 前缀。此时,你需要把 `resolveExtensionPrefix` 设置为一个对象,对象的 key 为对应的产物类型。
41
+
42
+ 比如为 `web` 和 `node` 设置不同的 extension 前缀:
43
+
44
+ ```js
45
+ export default {
46
+ output: {
47
+ source: {
48
+ resolveExtensionPrefix: {
49
+ web: '.web',
50
+ node: '.node',
51
+ },
52
+ },
53
+ },
54
+ };
55
+ ```
56
+
57
+ 在代码中 `import './foo'` 时,对于 node 产物,会优先识别 `foo.node.js` 文件,而对于 web 产物,则会优先识别 `foo.web.js` 文件。
@@ -4,6 +4,43 @@ title: resolveMainFields
4
4
 
5
5
  # source.resolveMainFields
6
6
 
7
- import Main from '@modern-js/builder-doc/docs/zh/config/source/resolveMainFields.md';
7
+ - **类型:**
8
8
 
9
- <Main />
9
+ ```ts
10
+ type Fields = (string | string[])[];
11
+
12
+ type ResolveMainFields = Fields | Record<BuilderTarget, Fields>;
13
+ ```
14
+
15
+ - **默认值:** `undefined`
16
+
17
+ 该配置项将决定你使用 `package.json` 哪个字段导入 `npm` 模块。对应 webpack 的 [resolve.mainFields](https://webpack.js.org/configuration/resolve/#resolvemainfields) 配置。
18
+
19
+ ### 示例
20
+
21
+ ```js
22
+ export default {
23
+ source: {
24
+ resolveMainFields: ['main', 'browser', 'exports'],
25
+ },
26
+ };
27
+ ```
28
+
29
+ #### 根据产物类型设置
30
+
31
+ 当你同时构建多种类型的产物时,你可以为不同的产物类型设置不同的 mainFields。此时,你需要把 `resolveMainFields` 设置为一个对象,对象的 key 为对应的产物类型。
32
+
33
+ 比如为 `web` 和 `node` 设置不同的 mainFields:
34
+
35
+ ```js
36
+ export default {
37
+ output: {
38
+ source: {
39
+ resolveMainFields: {
40
+ web: ['main', 'browser', 'exports'],
41
+ node: ['main', 'node', 'exports'],
42
+ },
43
+ },
44
+ },
45
+ };
46
+ ```
@@ -1,9 +1,63 @@
1
1
  ---
2
2
  title: transformImport
3
+ configName: source.transformImport
3
4
  ---
4
5
 
5
6
  # source.transformImport
6
7
 
7
- import Main from '@modern-js/builder-doc/docs/zh/config/source/transformImport.md';
8
+ 转换 import 的路径,可以用于模块化引用三方包的子路径,能力类似于 [babel-plugin-import](https://www.npmjs.com/package/babel-plugin-import)。
8
9
 
9
- <Main />
10
+ - **类型:**
11
+
12
+ ```ts
13
+ type TransformImport =
14
+ | Array<{
15
+ libraryName: string;
16
+ libraryDirectory?: string;
17
+ style?: string | boolean;
18
+ styleLibraryDirectory?: string;
19
+ camelToDashComponentName?: boolean;
20
+ transformToDefaultImport?: boolean;
21
+ customName?: string;
22
+ customStyleName?: string;
23
+ }>
24
+ | Function;
25
+ ```
26
+
27
+ - **默认值:**
28
+
29
+ 当项目中安装了 [Ant Design 组件库](https://www.npmjs.com/package/antd) &lt;= 4.x 版本时,Modern.js 会自动添加以下默认配置:
30
+
31
+ ```js
32
+ const defaultAntdConfig = {
33
+ libraryName: 'antd',
34
+ libraryDirectory: isServer ? 'lib' : 'es',
35
+ style: true,
36
+ };
37
+ ```
38
+
39
+ 当项目中安装了 [Arco Design 组件库](https://www.npmjs.com/package/@arco-design/web-react) 时,Modern.js 会自动添加以下默认配置:
40
+
41
+ ```js
42
+ const defaultArcoConfig = [
43
+ {
44
+ libraryName: '@arco-design/web-react',
45
+ libraryDirectory: isServer ? 'lib' : 'es',
46
+ camelToDashComponentName: false,
47
+ style: true,
48
+ },
49
+ {
50
+ libraryName: '@arco-design/web-react/icon',
51
+ libraryDirectory: isServer ? 'react-icon-cjs' : 'react-icon',
52
+ camelToDashComponentName: false,
53
+ },
54
+ ];
55
+ ```
56
+
57
+ :::tip
58
+ 当你添加了 `antd` 或 `@arco-design/web-react` 相关的配置时,优先级会高于上述默认配置。
59
+ :::
60
+
61
+ import RsbuildConig from '@site-docs/components/rsbuild-config-tooltip';
62
+
63
+ <RsbuildConig />
@@ -4,6 +4,45 @@ title: autoprefixer
4
4
 
5
5
  # tools.autoprefixer
6
6
 
7
- import Main from '@modern-js/builder-doc/docs/zh/config/tools/autoprefixer.md';
7
+ - **类型:** `Object | Function`
8
+ - **默认值:**
8
9
 
9
- <Main />
10
+ ```js
11
+ {
12
+ flexbox: 'no-2009',
13
+ // browserslist 取决于项目中的 browserslist 配置
14
+ // 以及 `output.overrideBrowserslist`(优先级更高) 配置
15
+ overrideBrowserslist: browserslist,
16
+ }
17
+ ```
18
+
19
+ 通过 `tools.autoprefixer` 可以修改 [autoprefixer](https://github.com/postcss/autoprefixer) 的配置。
20
+
21
+ ### Object 类型
22
+
23
+ 当 `tools.autoprefixer` 的值为 `Object` 类型时,会与默认配置通过 Object.assign 合并。比如:
24
+
25
+ ```js
26
+ export default {
27
+ tools: {
28
+ autoprefixer: {
29
+ flexbox: 'no-2009',
30
+ },
31
+ },
32
+ };
33
+ ```
34
+
35
+ ### Function 类型
36
+
37
+ 当 `tools.autoprefixer` 为 Function 类型时,默认配置作为第一个参数传入,可以直接修改配置对象,也可以返回一个值作为最终结果。比如:
38
+
39
+ ```js
40
+ export default {
41
+ tools: {
42
+ autoprefixer(config) {
43
+ // 修改 flexbox 的配置
44
+ config.flexbox = 'no-2009';
45
+ },
46
+ },
47
+ };
48
+ ```