@modern-js/main-doc 2.59.0 → 2.60.1-alpha.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (414) hide show
  1. package/docs/en/_meta.json +10 -5
  2. package/docs/en/apis/app/hooks/api/lambda.mdx +4 -48
  3. package/docs/en/apis/app/hooks/api/middleware.mdx +11 -0
  4. package/docs/en/community/blog/v2-release-note.mdx +1 -1
  5. package/docs/en/community/contributing-guide.mdx +0 -1
  6. package/docs/en/components/builder.mdx +3 -0
  7. package/docs/en/components/bundler.mdx +3 -0
  8. package/docs/en/components/enable-bff.mdx +19 -2
  9. package/docs/en/components/enableSwc.mdx +17 -0
  10. package/docs/en/components/esbuild.mdx +3 -0
  11. package/docs/en/components/extend-bff-function.mdx +5 -0
  12. package/docs/en/components/micro-frontend.mdx +6 -0
  13. package/docs/en/components/module-federation.mdx +7 -0
  14. package/docs/en/components/nodeVersion.mdx +26 -0
  15. package/docs/en/components/other-plugins.mdx +0 -0
  16. package/docs/en/components/output-asset-prefix-extend.mdx +0 -0
  17. package/docs/en/components/output-polyfill-extend.mdx +0 -0
  18. package/docs/en/components/prerequisites.mdx +1 -1
  19. package/docs/en/components/rsbuild-config-tooltip.mdx +5 -0
  20. package/docs/en/components/rsbuild.mdx +3 -0
  21. package/docs/en/components/rspack.mdx +3 -0
  22. package/docs/en/components/rspackPrecautions.mdx +6 -0
  23. package/docs/en/components/rspackTip.mdx +7 -0
  24. package/docs/en/components/swc.mdx +3 -0
  25. package/docs/en/configure/app/auto-load-plugin.mdx +4 -0
  26. package/docs/en/configure/app/dev/asset-prefix.mdx +12 -2
  27. package/docs/en/configure/app/dev/before-start-url.mdx +14 -2
  28. package/docs/en/configure/app/dev/client.mdx +20 -16
  29. package/docs/en/configure/app/dev/hmr.mdx +8 -2
  30. package/docs/en/configure/app/dev/host.mdx +15 -2
  31. package/docs/en/configure/app/dev/https.mdx +71 -2
  32. package/docs/en/configure/app/dev/live-reload.mdx +3 -15
  33. package/docs/en/configure/app/dev/port.mdx +18 -2
  34. package/docs/en/configure/app/dev/progress-bar.mdx +17 -2
  35. package/docs/en/configure/app/dev/setup-middlewares.mdx +25 -39
  36. package/docs/en/configure/app/dev/start-url.mdx +46 -2
  37. package/docs/en/configure/app/dev/watch-files.mdx +5 -39
  38. package/docs/en/configure/app/dev/write-to-disk.mdx +4 -27
  39. package/docs/en/configure/app/experiments/lazy-compilation.mdx +84 -2
  40. package/docs/en/configure/app/experiments/source-build.mdx +28 -3
  41. package/docs/en/configure/app/html/app-icon.mdx +48 -2
  42. package/docs/en/configure/app/html/crossorigin.mdx +8 -2
  43. package/docs/en/configure/app/html/disable-html-folder.mdx +35 -2
  44. package/docs/en/configure/app/html/favicon-by-entries.mdx +29 -2
  45. package/docs/en/configure/app/html/favicon.mdx +14 -2
  46. package/docs/en/configure/app/html/inject-by-entries.mdx +29 -2
  47. package/docs/en/configure/app/html/inject.mdx +8 -2
  48. package/docs/en/configure/app/html/meta-by-entries.mdx +41 -2
  49. package/docs/en/configure/app/html/meta.mdx +22 -2
  50. package/docs/en/configure/app/html/mount-id.mdx +8 -2
  51. package/docs/en/configure/app/html/script-loading.mdx +8 -2
  52. package/docs/en/configure/app/html/tags-by-entries.mdx +37 -2
  53. package/docs/en/configure/app/html/tags.mdx +13 -2
  54. package/docs/en/configure/app/html/template-by-entries.mdx +26 -2
  55. package/docs/en/configure/app/html/template-parameters-by-entries.mdx +28 -2
  56. package/docs/en/configure/app/html/template-parameters.mdx +31 -2
  57. package/docs/en/configure/app/html/template.mdx +8 -2
  58. package/docs/en/configure/app/html/title-by-entries.mdx +30 -2
  59. package/docs/en/configure/app/html/title.mdx +16 -2
  60. package/docs/en/configure/app/output/asset-prefix.mdx +12 -2
  61. package/docs/en/configure/app/output/assets-retry.mdx +72 -2
  62. package/docs/en/configure/app/output/charset.mdx +8 -2
  63. package/docs/en/configure/app/output/clean-dist-path.mdx +13 -2
  64. package/docs/en/configure/app/output/convert-to-rem.mdx +76 -2
  65. package/docs/en/configure/app/output/copy.mdx +5 -2
  66. package/docs/en/configure/app/output/css-module-local-ident-name.mdx +14 -2
  67. package/docs/en/configure/app/output/css-modules.mdx +46 -2
  68. package/docs/en/configure/app/output/data-uri-limit.mdx +24 -2
  69. package/docs/en/configure/app/output/disable-css-extract.mdx +9 -2
  70. package/docs/en/configure/app/output/disable-css-module-extension.mdx +52 -2
  71. package/docs/en/configure/app/output/disable-filename-hash.mdx +9 -2
  72. package/docs/en/configure/app/output/disable-inline-runtime-chunk.mdx +38 -2
  73. package/docs/en/configure/app/output/disable-minimize.mdx +7 -2
  74. package/docs/en/configure/app/output/disable-source-map.mdx +24 -2
  75. package/docs/en/configure/app/output/disable-svgr.mdx +13 -2
  76. package/docs/en/configure/app/output/disable-ts-checker.mdx +46 -2
  77. package/docs/en/configure/app/output/dist-path.mdx +39 -2
  78. package/docs/en/configure/app/output/enable-asset-fallback.mdx +29 -2
  79. package/docs/en/configure/app/output/enable-asset-manifest.mdx +33 -2
  80. package/docs/en/configure/app/output/enable-css-module-tsdeclaration.mdx +25 -2
  81. package/docs/en/configure/app/output/enable-inline-scripts.mdx +15 -2
  82. package/docs/en/configure/app/output/enable-inline-styles.mdx +15 -2
  83. package/docs/en/configure/app/output/enable-latest-decorators.mdx +7 -2
  84. package/docs/en/configure/app/output/externals.mdx +18 -2
  85. package/docs/en/configure/app/output/filename-hash.mdx +3 -27
  86. package/docs/en/configure/app/output/filename.mdx +47 -2
  87. package/docs/en/configure/app/output/inject-styles.mdx +15 -0
  88. package/docs/en/configure/app/output/inline-scripts.mdx +34 -0
  89. package/docs/en/configure/app/output/inline-styles.mdx +34 -0
  90. package/docs/en/configure/app/output/legal-comments.mdx +16 -2
  91. package/docs/en/configure/app/output/minify.mdx +27 -0
  92. package/docs/en/configure/app/output/override-browserslist.mdx +18 -2
  93. package/docs/en/configure/app/output/polyfill.mdx +12 -2
  94. package/docs/en/configure/app/output/source-map.mdx +30 -0
  95. package/docs/en/configure/app/output/ssg.mdx +20 -17
  96. package/docs/en/configure/app/output/svg-default-export.mdx +27 -2
  97. package/docs/en/configure/app/performance/build-cache.mdx +78 -2
  98. package/docs/en/configure/app/performance/bundle-analyze.mdx +18 -2
  99. package/docs/en/configure/app/performance/chunk-split.mdx +38 -2
  100. package/docs/en/configure/app/performance/dns-prefetch.mdx +13 -2
  101. package/docs/en/configure/app/performance/preconnect.mdx +14 -2
  102. package/docs/en/configure/app/performance/prefetch.mdx +19 -2
  103. package/docs/en/configure/app/performance/preload.mdx +21 -2
  104. package/docs/en/configure/app/performance/print-file-size.mdx +38 -2
  105. package/docs/en/configure/app/performance/profile.mdx +8 -2
  106. package/docs/en/configure/app/performance/remove-console.mdx +8 -2
  107. package/docs/en/configure/app/performance/remove-moment-locale.mdx +8 -2
  108. package/docs/en/configure/app/performance/transform-lodash.mdx +42 -2
  109. package/docs/en/configure/app/plugins.mdx +3 -3
  110. package/docs/en/configure/app/security/check-syntax.mdx +66 -2
  111. package/docs/en/configure/app/security/nonce.mdx +13 -2
  112. package/docs/en/configure/app/security/sri.mdx +19 -2
  113. package/docs/en/configure/app/server/port.mdx +5 -0
  114. package/docs/en/configure/app/server/ssr.mdx +10 -9
  115. package/docs/en/configure/app/source/alias-strategy.mdx +8 -2
  116. package/docs/en/configure/app/source/alias.mdx +17 -2
  117. package/docs/en/configure/app/source/config-dir.mdx +1 -1
  118. package/docs/en/configure/app/source/decorators.mdx +8 -21
  119. package/docs/en/configure/app/source/define.mdx +14 -2
  120. package/docs/en/configure/app/source/enable-async-entry.mdx +1 -1
  121. package/docs/en/configure/app/source/entries-dir.mdx +1 -1
  122. package/docs/en/configure/app/source/exclude.mdx +8 -2
  123. package/docs/en/configure/app/source/global-vars.mdx +103 -2
  124. package/docs/en/configure/app/source/include.mdx +19 -2
  125. package/docs/en/configure/app/source/mainEntryName.mdx +1 -1
  126. package/docs/en/configure/app/source/module-scopes.mdx +62 -2
  127. package/docs/en/configure/app/source/pre-entry.mdx +8 -2
  128. package/docs/en/configure/app/source/resolve-extension-prefix.mdx +48 -2
  129. package/docs/en/configure/app/source/resolve-main-fields.mdx +39 -2
  130. package/docs/en/configure/app/source/transform-import.mdx +56 -2
  131. package/docs/en/configure/app/tools/autoprefixer.mdx +41 -2
  132. package/docs/en/configure/app/tools/babel.mdx +218 -2
  133. package/docs/en/configure/app/tools/bundler-chain.mdx +23 -2
  134. package/docs/en/configure/app/tools/css-extract.mdx +31 -2
  135. package/docs/en/configure/app/tools/css-loader.mdx +14 -2
  136. package/docs/en/configure/app/tools/dev-server.mdx +435 -2
  137. package/docs/en/configure/app/tools/esbuild.mdx +2 -2
  138. package/docs/en/configure/app/tools/html-plugin.mdx +21 -2
  139. package/docs/en/configure/app/tools/less.mdx +78 -2
  140. package/docs/en/configure/app/tools/minify-css.mdx +50 -2
  141. package/docs/en/configure/app/tools/postcss.mdx +30 -2
  142. package/docs/en/configure/app/tools/pug.mdx +47 -2
  143. package/docs/en/configure/app/tools/rspack.mdx +8 -2
  144. package/docs/en/configure/app/tools/sass.mdx +75 -2
  145. package/docs/en/configure/app/tools/style-loader.mdx +8 -2
  146. package/docs/en/configure/app/tools/styled-components.mdx +48 -2
  147. package/docs/en/configure/app/tools/swc.mdx +34 -3
  148. package/docs/en/configure/app/tools/terser.mdx +49 -2
  149. package/docs/en/configure/app/tools/ts-checker.mdx +49 -2
  150. package/docs/en/configure/app/tools/ts-loader.mdx +63 -2
  151. package/docs/en/configure/app/tools/webpack-chain.mdx +239 -2
  152. package/docs/en/configure/app/tools/webpack.mdx +295 -2
  153. package/docs/en/guides/_meta.json +0 -5
  154. package/docs/en/guides/advanced-features/_meta.json +7 -5
  155. package/docs/en/guides/advanced-features/bff/_meta.json +1 -1
  156. package/docs/en/guides/advanced-features/bff/extend-server.mdx +154 -0
  157. package/docs/en/guides/advanced-features/bff/frameworks.mdx +52 -123
  158. package/docs/en/guides/advanced-features/bff/function.mdx +108 -80
  159. package/docs/en/guides/advanced-features/bff/sdk.mdx +40 -51
  160. package/docs/en/guides/advanced-features/build-performance.mdx +6 -21
  161. package/docs/en/guides/advanced-features/page-performance/_meta.json +1 -0
  162. package/docs/en/guides/advanced-features/rspack-start.mdx +2 -2
  163. package/docs/en/guides/basic-features/css/css-modules.mdx +2 -2
  164. package/docs/en/guides/basic-features/output-files.mdx +1 -1
  165. package/docs/en/guides/basic-features/render/ssg.mdx +1 -1
  166. package/docs/en/guides/basic-features/render/streaming-ssr.mdx +1 -1
  167. package/docs/en/guides/basic-features/routes.mdx +2 -3
  168. package/docs/en/guides/basic-features/static-assets.mdx +1 -1
  169. package/docs/en/guides/concept/builder.mdx +1 -1
  170. package/docs/en/guides/deprecated.md +2 -0
  171. package/docs/en/guides/get-started/glossary.mdx +7 -7
  172. package/docs/en/guides/get-started/quick-start.mdx +1 -1
  173. package/docs/en/guides/topic-detail/_meta.json +0 -6
  174. package/docs/en/guides/topic-detail/micro-frontend/c01-introduction.mdx +1 -1
  175. package/docs/en/guides/troubleshooting/builder.mdx +2 -2
  176. package/docs/en/plugin/_meta.json +19 -0
  177. package/docs/en/plugin/cli-plugins/_meta.json +1 -0
  178. package/docs/en/plugin/cli-plugins/plugin-bff.mdx +5 -0
  179. package/docs/en/plugin/cli-plugins/plugin-ssg.mdx +5 -0
  180. package/docs/en/{guides/rsbuild-plugins → plugin/cli-plugins}/plugin-swc.mdx +11 -4
  181. package/docs/en/plugin/cli-plugins/plugin-tailwind.mdx +5 -0
  182. package/docs/en/plugin/cli-plugins.mdx +6 -0
  183. package/docs/en/{guides/advanced-features/rsbuild-plugin.mdx → plugin/introduction.mdx} +34 -9
  184. package/docs/en/{guides/topic-detail/framework-plugin → plugin/plugin-system}/extend.mdx +1 -1
  185. package/docs/en/{guides/topic-detail/framework-plugin → plugin/plugin-system}/implement.mdx +3 -3
  186. package/docs/en/{guides/topic-detail/framework-plugin → plugin/plugin-system}/plugin-api.mdx +2 -2
  187. package/docs/en/plugin/rsbuild-plugins/_meta.json +1 -0
  188. package/docs/en/{guides → plugin}/rsbuild-plugins/plugin-esbuild.mdx +4 -4
  189. package/docs/en/plugin/rsbuild-plugins.mdx +3 -0
  190. package/docs/zh/_meta.json +10 -5
  191. package/docs/zh/apis/app/hooks/api/lambda.mdx +5 -48
  192. package/docs/zh/apis/app/hooks/api/middleware.mdx +11 -0
  193. package/docs/zh/community/blog/v2-release-note.mdx +1 -1
  194. package/docs/zh/community/contributing-guide.mdx +0 -1
  195. package/docs/zh/components/builder.mdx +3 -0
  196. package/docs/zh/components/bundler.mdx +4 -0
  197. package/docs/zh/components/enable-bff.mdx +19 -2
  198. package/docs/zh/components/enableSwc.mdx +17 -0
  199. package/docs/zh/components/esbuild.mdx +3 -0
  200. package/docs/zh/components/extend-bff-function.mdx +5 -0
  201. package/docs/zh/components/micro-frontend.mdx +6 -0
  202. package/docs/zh/components/module-federation.mdx +7 -0
  203. package/docs/zh/components/nodeVersion.mdx +28 -0
  204. package/docs/zh/components/other-plugins.mdx +0 -0
  205. package/docs/zh/components/output-asset-prefix-extend.mdx +0 -0
  206. package/docs/zh/components/output-polyfill-extend.mdx +0 -0
  207. package/docs/zh/components/prerequisites.mdx +1 -1
  208. package/docs/zh/components/rsbuild-config-tooltip.mdx +5 -0
  209. package/docs/zh/components/rsbuild.mdx +3 -0
  210. package/docs/zh/components/rspack.mdx +3 -0
  211. package/docs/zh/components/rspackPrecautions.mdx +6 -0
  212. package/docs/zh/components/rspackTip.mdx +7 -0
  213. package/docs/zh/components/swc.mdx +3 -0
  214. package/docs/zh/configure/app/auto-load-plugin.mdx +4 -0
  215. package/docs/zh/configure/app/dev/asset-prefix.mdx +12 -2
  216. package/docs/zh/configure/app/dev/before-start-url.mdx +14 -2
  217. package/docs/zh/configure/app/dev/client.mdx +20 -16
  218. package/docs/zh/configure/app/dev/hmr.mdx +8 -2
  219. package/docs/zh/configure/app/dev/host.mdx +15 -2
  220. package/docs/zh/configure/app/dev/https.mdx +72 -2
  221. package/docs/zh/configure/app/dev/live-reload.mdx +3 -15
  222. package/docs/zh/configure/app/dev/port.mdx +18 -2
  223. package/docs/zh/configure/app/dev/progress-bar.mdx +17 -2
  224. package/docs/zh/configure/app/dev/setup-middlewares.mdx +26 -39
  225. package/docs/zh/configure/app/dev/start-url.mdx +47 -2
  226. package/docs/zh/configure/app/dev/watch-files.mdx +5 -39
  227. package/docs/zh/configure/app/dev/write-to-disk.mdx +3 -26
  228. package/docs/zh/configure/app/experiments/lazy-compilation.mdx +84 -2
  229. package/docs/zh/configure/app/experiments/source-build.mdx +29 -2
  230. package/docs/zh/configure/app/html/app-icon.mdx +48 -2
  231. package/docs/zh/configure/app/html/crossorigin.mdx +9 -2
  232. package/docs/zh/configure/app/html/disable-html-folder.mdx +34 -2
  233. package/docs/zh/configure/app/html/favicon-by-entries.mdx +30 -2
  234. package/docs/zh/configure/app/html/favicon.mdx +15 -2
  235. package/docs/zh/configure/app/html/inject-by-entries.mdx +30 -2
  236. package/docs/zh/configure/app/html/inject.mdx +8 -2
  237. package/docs/zh/configure/app/html/meta-by-entries.mdx +41 -2
  238. package/docs/zh/configure/app/html/meta.mdx +22 -2
  239. package/docs/zh/configure/app/html/mount-id.mdx +8 -2
  240. package/docs/zh/configure/app/html/script-loading.mdx +8 -2
  241. package/docs/zh/configure/app/html/tags-by-entries.mdx +37 -2
  242. package/docs/zh/configure/app/html/tags.mdx +13 -2
  243. package/docs/zh/configure/app/html/template-by-entries.mdx +26 -2
  244. package/docs/zh/configure/app/html/template-parameters-by-entries.mdx +29 -2
  245. package/docs/zh/configure/app/html/template-parameters.mdx +31 -2
  246. package/docs/zh/configure/app/html/template.mdx +8 -2
  247. package/docs/zh/configure/app/html/title-by-entries.mdx +30 -2
  248. package/docs/zh/configure/app/html/title.mdx +16 -2
  249. package/docs/zh/configure/app/output/asset-prefix.mdx +12 -2
  250. package/docs/zh/configure/app/output/assets-retry.mdx +72 -2
  251. package/docs/zh/configure/app/output/charset.mdx +8 -2
  252. package/docs/zh/configure/app/output/clean-dist-path.mdx +13 -2
  253. package/docs/zh/configure/app/output/convert-to-rem.mdx +77 -2
  254. package/docs/zh/configure/app/output/copy.mdx +6 -2
  255. package/docs/zh/configure/app/output/css-module-local-ident-name.mdx +14 -2
  256. package/docs/zh/configure/app/output/css-modules.mdx +46 -2
  257. package/docs/zh/configure/app/output/data-uri-limit.mdx +24 -2
  258. package/docs/zh/configure/app/output/disable-css-extract.mdx +9 -2
  259. package/docs/zh/configure/app/output/disable-css-module-extension.mdx +52 -2
  260. package/docs/zh/configure/app/output/disable-filename-hash.mdx +9 -2
  261. package/docs/zh/configure/app/output/disable-inline-runtime-chunk.mdx +38 -2
  262. package/docs/zh/configure/app/output/disable-minimize.mdx +7 -2
  263. package/docs/zh/configure/app/output/disable-source-map.mdx +24 -2
  264. package/docs/zh/configure/app/output/disable-svgr.mdx +14 -2
  265. package/docs/zh/configure/app/output/disable-ts-checker.mdx +46 -2
  266. package/docs/zh/configure/app/output/dist-path.mdx +39 -2
  267. package/docs/zh/configure/app/output/enable-asset-fallback.mdx +29 -2
  268. package/docs/zh/configure/app/output/enable-asset-manifest.mdx +33 -2
  269. package/docs/zh/configure/app/output/enable-css-module-tsdeclaration.mdx +25 -2
  270. package/docs/zh/configure/app/output/enable-inline-scripts.mdx +15 -2
  271. package/docs/zh/configure/app/output/enable-inline-styles.mdx +15 -2
  272. package/docs/zh/configure/app/output/enable-latest-decorators.mdx +7 -2
  273. package/docs/zh/configure/app/output/externals.mdx +18 -2
  274. package/docs/zh/configure/app/output/filename-hash.mdx +4 -27
  275. package/docs/zh/configure/app/output/filename.mdx +47 -2
  276. package/docs/zh/configure/app/output/inject-styles.mdx +15 -0
  277. package/docs/zh/configure/app/output/inline-scripts.mdx +34 -0
  278. package/docs/zh/configure/app/output/inline-styles.mdx +34 -0
  279. package/docs/zh/configure/app/output/legal-comments.mdx +16 -2
  280. package/docs/zh/configure/app/output/minify.mdx +27 -0
  281. package/docs/zh/configure/app/output/override-browserslist.mdx +20 -2
  282. package/docs/zh/configure/app/output/polyfill.mdx +12 -2
  283. package/docs/zh/configure/app/output/source-map.mdx +30 -0
  284. package/docs/zh/configure/app/output/ssg.mdx +19 -15
  285. package/docs/zh/configure/app/output/svg-default-export.mdx +27 -2
  286. package/docs/zh/configure/app/performance/build-cache.mdx +77 -2
  287. package/docs/zh/configure/app/performance/bundle-analyze.mdx +18 -2
  288. package/docs/zh/configure/app/performance/chunk-split.mdx +38 -2
  289. package/docs/zh/configure/app/performance/dns-prefetch.mdx +13 -2
  290. package/docs/zh/configure/app/performance/preconnect.mdx +14 -2
  291. package/docs/zh/configure/app/performance/prefetch.mdx +19 -2
  292. package/docs/zh/configure/app/performance/preload.mdx +21 -2
  293. package/docs/zh/configure/app/performance/print-file-size.mdx +38 -2
  294. package/docs/zh/configure/app/performance/profile.mdx +8 -2
  295. package/docs/zh/configure/app/performance/remove-console.mdx +8 -2
  296. package/docs/zh/configure/app/performance/remove-moment-locale.mdx +8 -2
  297. package/docs/zh/configure/app/performance/transform-lodash.mdx +42 -2
  298. package/docs/zh/configure/app/plugins.mdx +3 -3
  299. package/docs/zh/configure/app/security/check-syntax.mdx +66 -2
  300. package/docs/zh/configure/app/security/nonce.mdx +13 -2
  301. package/docs/zh/configure/app/security/sri.mdx +19 -2
  302. package/docs/zh/configure/app/server/port.mdx +5 -0
  303. package/docs/zh/configure/app/server/ssr.mdx +10 -9
  304. package/docs/zh/configure/app/source/alias-strategy.mdx +8 -2
  305. package/docs/zh/configure/app/source/alias.mdx +17 -2
  306. package/docs/zh/configure/app/source/config-dir.mdx +1 -1
  307. package/docs/zh/configure/app/source/decorators.mdx +8 -20
  308. package/docs/zh/configure/app/source/define.mdx +14 -2
  309. package/docs/zh/configure/app/source/enable-async-entry.mdx +1 -1
  310. package/docs/zh/configure/app/source/entries-dir.mdx +1 -1
  311. package/docs/zh/configure/app/source/exclude.mdx +8 -2
  312. package/docs/zh/configure/app/source/global-vars.mdx +102 -2
  313. package/docs/zh/configure/app/source/include.mdx +19 -2
  314. package/docs/zh/configure/app/source/mainEntryName.mdx +1 -1
  315. package/docs/zh/configure/app/source/module-scopes.mdx +62 -2
  316. package/docs/zh/configure/app/source/pre-entry.mdx +8 -2
  317. package/docs/zh/configure/app/source/resolve-extension-prefix.mdx +50 -2
  318. package/docs/zh/configure/app/source/resolve-main-fields.mdx +39 -2
  319. package/docs/zh/configure/app/source/transform-import.mdx +56 -2
  320. package/docs/zh/configure/app/tools/autoprefixer.mdx +41 -2
  321. package/docs/zh/configure/app/tools/babel.mdx +218 -2
  322. package/docs/zh/configure/app/tools/bundler-chain.mdx +26 -2
  323. package/docs/zh/configure/app/tools/css-extract.mdx +28 -2
  324. package/docs/zh/configure/app/tools/css-loader.mdx +15 -2
  325. package/docs/zh/configure/app/tools/dev-server.mdx +435 -2
  326. package/docs/zh/configure/app/tools/esbuild.mdx +2 -2
  327. package/docs/zh/configure/app/tools/html-plugin.mdx +21 -2
  328. package/docs/zh/configure/app/tools/less.mdx +79 -2
  329. package/docs/zh/configure/app/tools/minify-css.mdx +50 -2
  330. package/docs/zh/configure/app/tools/postcss.mdx +31 -2
  331. package/docs/zh/configure/app/tools/pug.mdx +47 -2
  332. package/docs/zh/configure/app/tools/rspack.mdx +8 -2
  333. package/docs/zh/configure/app/tools/sass.mdx +73 -2
  334. package/docs/zh/configure/app/tools/style-loader.mdx +8 -2
  335. package/docs/zh/configure/app/tools/styled-components.mdx +47 -2
  336. package/docs/zh/configure/app/tools/swc.mdx +34 -3
  337. package/docs/zh/configure/app/tools/terser.mdx +49 -2
  338. package/docs/zh/configure/app/tools/ts-checker.mdx +49 -2
  339. package/docs/zh/configure/app/tools/ts-loader.mdx +63 -2
  340. package/docs/zh/configure/app/tools/webpack-chain.mdx +243 -2
  341. package/docs/zh/configure/app/tools/webpack.mdx +295 -2
  342. package/docs/zh/guides/_meta.json +0 -5
  343. package/docs/zh/guides/advanced-features/_meta.json +7 -5
  344. package/docs/zh/guides/advanced-features/bff/_meta.json +1 -1
  345. package/docs/zh/guides/advanced-features/bff/extend-server.mdx +156 -0
  346. package/docs/zh/guides/advanced-features/bff/frameworks.mdx +51 -117
  347. package/docs/zh/guides/advanced-features/bff/function.mdx +69 -59
  348. package/docs/zh/guides/advanced-features/bff/sdk.mdx +27 -36
  349. package/docs/zh/guides/advanced-features/build-performance.mdx +6 -21
  350. package/docs/zh/guides/advanced-features/page-performance/_meta.json +1 -0
  351. package/docs/zh/guides/advanced-features/rspack-start.mdx +4 -4
  352. package/docs/zh/guides/basic-features/alias.mdx +5 -11
  353. package/docs/zh/guides/basic-features/css/css-modules.mdx +1 -1
  354. package/docs/zh/guides/basic-features/env-vars.mdx +1 -1
  355. package/docs/zh/guides/basic-features/output-files.mdx +2 -2
  356. package/docs/zh/guides/basic-features/routes.mdx +1 -2
  357. package/docs/zh/guides/basic-features/static-assets.mdx +1 -1
  358. package/docs/zh/guides/concept/builder.mdx +1 -1
  359. package/docs/zh/guides/deprecated.md +4 -0
  360. package/docs/zh/guides/get-started/glossary.mdx +7 -7
  361. package/docs/zh/guides/get-started/quick-start.mdx +1 -1
  362. package/docs/zh/guides/topic-detail/_meta.json +0 -6
  363. package/docs/zh/guides/topic-detail/micro-frontend/c01-introduction.mdx +1 -1
  364. package/docs/zh/guides/troubleshooting/builder.mdx +2 -2
  365. package/docs/zh/plugin/_meta.json +19 -0
  366. package/docs/zh/plugin/cli-plugins/_meta.json +1 -0
  367. package/docs/zh/plugin/cli-plugins/plugin-bff.mdx +5 -0
  368. package/docs/zh/plugin/cli-plugins/plugin-ssg.mdx +5 -0
  369. package/docs/zh/{guides/rsbuild-plugins → plugin/cli-plugins}/plugin-swc.mdx +11 -4
  370. package/docs/zh/plugin/cli-plugins/plugin-tailwind.mdx +5 -0
  371. package/docs/zh/plugin/cli-plugins.mdx +6 -0
  372. package/docs/zh/{guides/advanced-features/rsbuild-plugin.mdx → plugin/introduction.mdx} +36 -11
  373. package/docs/zh/{guides/topic-detail/framework-plugin → plugin/plugin-system}/extend.mdx +1 -1
  374. package/docs/zh/{guides/topic-detail/framework-plugin → plugin/plugin-system}/implement.mdx +3 -3
  375. package/docs/zh/{guides/topic-detail/framework-plugin → plugin/plugin-system}/plugin-api.mdx +2 -2
  376. package/docs/zh/plugin/rsbuild-plugins/_meta.json +1 -0
  377. package/docs/zh/{guides → plugin}/rsbuild-plugins/plugin-esbuild.mdx +6 -6
  378. package/docs/zh/plugin/rsbuild-plugins.mdx +4 -0
  379. package/i18n.json +27 -3
  380. package/package.json +8 -13
  381. package/rspress.config.ts +1 -58
  382. package/src/components/Footer/index.tsx +1 -1
  383. package/src/components/RsbuildLink/index.tsx +19 -0
  384. package/src/pages/index.tsx +0 -1
  385. package/docs/en/apis/app/hooks/api/api.mdx +0 -80
  386. package/docs/en/apis/app/hooks/api/app.mdx +0 -12
  387. package/docs/en/guides/advanced-features/bff/type.mdx +0 -46
  388. package/docs/en/guides/advanced-features/eslint.mdx +0 -148
  389. package/docs/zh/apis/app/hooks/api/api.mdx +0 -81
  390. package/docs/zh/apis/app/hooks/api/app.mdx +0 -12
  391. package/docs/zh/guides/advanced-features/bff/type.mdx +0 -46
  392. package/docs/zh/guides/advanced-features/eslint.mdx +0 -152
  393. /package/docs/en/configure/app/output/{splitRouteChunks.mdx → split-route-chunks.mdx} +0 -0
  394. /package/docs/en/guides/advanced-features/{bff/index.mdx → bff.mdx} +0 -0
  395. /package/docs/en/guides/advanced-features/{code-split.mdx → page-performance/code-split.mdx} +0 -0
  396. /package/docs/en/guides/advanced-features/{inline-assets.mdx → page-performance/inline-assets.mdx} +0 -0
  397. /package/docs/en/guides/advanced-features/{optimize-bundle.mdx → page-performance/optimize-bundle.mdx} +0 -0
  398. /package/docs/en/{guides/topic-detail/framework-plugin → plugin/plugin-system}/_meta.json +0 -0
  399. /package/docs/en/{guides/topic-detail/framework-plugin → plugin/plugin-system}/hook-list.mdx +0 -0
  400. /package/docs/en/{guides/topic-detail/framework-plugin → plugin/plugin-system}/hook.mdx +0 -0
  401. /package/docs/en/{guides/topic-detail/framework-plugin → plugin/plugin-system}/introduction.mdx +0 -0
  402. /package/docs/en/{guides/topic-detail/framework-plugin → plugin/plugin-system}/lifecycle.mdx +0 -0
  403. /package/docs/en/{guides/topic-detail/framework-plugin → plugin/plugin-system}/relationship.mdx +0 -0
  404. /package/docs/zh/configure/app/output/{splitRouteChunks.mdx → split-route-chunks.mdx} +0 -0
  405. /package/docs/zh/guides/advanced-features/{bff/index.mdx → bff.mdx} +0 -0
  406. /package/docs/zh/guides/advanced-features/{code-split.mdx → page-performance/code-split.mdx} +0 -0
  407. /package/docs/zh/guides/advanced-features/{inline-assets.mdx → page-performance/inline-assets.mdx} +0 -0
  408. /package/docs/zh/guides/advanced-features/{optimize-bundle.mdx → page-performance/optimize-bundle.mdx} +0 -0
  409. /package/docs/zh/{guides/topic-detail/framework-plugin → plugin/plugin-system}/_meta.json +0 -0
  410. /package/docs/zh/{guides/topic-detail/framework-plugin → plugin/plugin-system}/hook-list.mdx +0 -0
  411. /package/docs/zh/{guides/topic-detail/framework-plugin → plugin/plugin-system}/hook.mdx +0 -0
  412. /package/docs/zh/{guides/topic-detail/framework-plugin → plugin/plugin-system}/introduction.mdx +0 -0
  413. /package/docs/zh/{guides/topic-detail/framework-plugin → plugin/plugin-system}/lifecycle.mdx +0 -0
  414. /package/docs/zh/{guides/topic-detail/framework-plugin → plugin/plugin-system}/relationship.mdx +0 -0
@@ -4,6 +4,37 @@ title: enableAssetManifest
4
4
 
5
5
  # output.enableAssetManifest
6
6
 
7
- import Main from '@modern-js/builder-doc/docs/zh/config/output/enableAssetManifest.md';
7
+ - **类型:** `boolean`
8
+ - **默认值:** `false`
8
9
 
9
- <Main />
10
+ 是否生成 manifest 文件,该文件包含所有构建产物的信息。
11
+
12
+ ### 示例
13
+
14
+ 添加以下配置来开启:
15
+
16
+ ```js
17
+ export default {
18
+ output: {
19
+ enableAssetManifest: true,
20
+ },
21
+ };
22
+ ```
23
+
24
+ 开启后,当编译完成时,会自动生成 `dist/asset-manifest.json` 文件:
25
+
26
+ ```json
27
+ {
28
+ "files": {
29
+ "main.css": "/static/css/main.45b01211.css",
30
+ "main.js": "/static/js/main.52fd298f.js",
31
+ "html/main/index.html": "/html/main/index.html"
32
+ },
33
+ "entrypoints": ["static/css/main.45b01211.css", "static/js/main.52fd298f.js"]
34
+ }
35
+ ```
36
+
37
+ 如果当前项目有多种类型构建产物,比如包含了 SSR 构建产物,那么会生成多份 manifest.json 文件。
38
+
39
+ - web 产物:`asset-manifest.json`
40
+ - node 产物:`asset-manifest-node.json`
@@ -4,6 +4,29 @@ title: enableCssModuleTSDeclaration
4
4
 
5
5
  # output.enableCssModuleTSDeclaration
6
6
 
7
- import Main from '@modern-js/builder-doc/docs/zh/config/output/enableCssModuleTSDeclaration.md';
7
+ - **类型:** `boolean`
8
+ - **默认值:** `false`
8
9
 
9
- <Main />
10
+ 是否生成 CSS Modules 的 TypeScript 声明文件。
11
+
12
+ ### Example
13
+
14
+ 启用 CSS Module TypeScript 声明,比如:
15
+
16
+ ```js
17
+ export default {
18
+ output: {
19
+ enableCssModuleTSDeclaration: true,
20
+ },
21
+ };
22
+ ```
23
+
24
+ 项目构建完成后,每个 CSS Module 文件都会生成一个 `.d.ts` 文件。例如:
25
+
26
+ ```ts
27
+ interface CssExports {
28
+ title: string;
29
+ }
30
+ export const cssExports: CssExports;
31
+ export default cssExports;
32
+ ```
@@ -4,6 +4,19 @@ title: enableInlineScripts
4
4
 
5
5
  # output.enableInlineScripts
6
6
 
7
- import Main from '@modern-js/builder-doc/docs/zh/config/output/enableInlineScripts.md';
7
+ - **类型:**
8
8
 
9
- <Main />
9
+ ```ts
10
+ type EnableInlineScripts =
11
+ | boolean
12
+ | RegExp
13
+ | ((params: { size: number; name: string }) => boolean);
14
+ ```
15
+
16
+ - **默认值:** `false`
17
+
18
+ 用来控制生产环境中是否用 `<script>` 标签将产物中的 script 文件(.js 文件)inline 到 HTML 中。
19
+
20
+ :::warning
21
+ **Deprecated**:该配置已废弃,请使用 `output.inlineScripts` 的布尔用法代替。
22
+ :::
@@ -4,6 +4,19 @@ title: enableInlineStyles
4
4
 
5
5
  # output.enableInlineStyles
6
6
 
7
- import Main from '@modern-js/builder-doc/docs/zh/config/output/enableInlineStyles.md';
7
+ - **类型:**
8
8
 
9
- <Main />
9
+ ```ts
10
+ type EnableInlineStyles =
11
+ | boolean
12
+ | RegExp
13
+ | ((params: { size: number; name: string }) => boolean);
14
+ ```
15
+
16
+ - **默认值:** `false`
17
+
18
+ 用来控制生产环境中是否用 `<style>` 标签将产物中的 style 文件(.css 文件)inline 到 HTML 中。
19
+
20
+ :::warning
21
+ **Deprecated**:该配置已废弃,请使用 `output.inlineStyles` 的布尔用法代替。
22
+ :::
@@ -4,6 +4,11 @@ title: enableLatestDecorators
4
4
 
5
5
  # output.enableLatestDecorators
6
6
 
7
- import Main from '@modern-js/builder-doc/docs/zh/config/output/enableLatestDecorators.md';
7
+ - **类型:** `boolean`
8
+ - **默认值:** `false`
8
9
 
9
- <Main />
10
+ 是否要使用 [新版 decorator 提案](https://github.com/tc39/proposal-decorators/tree/7fa580b40f2c19c561511ea2c978e307ae689a1b) 进行编译。
11
+
12
+ :::warning
13
+ **Deprecated**:该配置已废弃,请使用 `source.decorators` 配置项代替。
14
+ :::
@@ -1,9 +1,25 @@
1
1
  ---
2
2
  title: externals
3
+ configName: output.externals
3
4
  ---
4
5
 
5
6
  # output.externals
6
7
 
7
- import Main from '@modern-js/builder-doc/docs/zh/config/output/externals.md';
8
+ - **类型:**
8
9
 
9
- <Main />
10
+ ```ts
11
+ type Externals =
12
+ | string
13
+ | object
14
+ | function
15
+ | RegExp
16
+ | Array<string | object | function | RegExp>;
17
+ ```
18
+
19
+ - **默认值:** `undefined`
20
+
21
+ 在构建时,防止将代码中某些 `import` 的依赖包打包到 bundle 中,而是在运行时再去从外部获取这些依赖。
22
+
23
+ import RsbuildConig from '@site-docs/components/rsbuild-config-tooltip';
24
+
25
+ <RsbuildConig />
@@ -1,5 +1,6 @@
1
1
  ---
2
2
  title: filenameHash
3
+ configName: output.filenameHash
3
4
  ---
4
5
 
5
6
  # output.filenameHash
@@ -7,32 +8,8 @@ title: filenameHash
7
8
  - **类型:** `boolean | string`
8
9
  - **默认值:** `true`
9
10
 
10
- 在生产环境构建后,是否在产物的文件名中添加 hash 值。
11
+ 在生产模式构建后,是否在产物的文件名中添加 hash 值。
11
12
 
12
- ### 示例
13
+ import RsbuildConig from '@site-docs/components/rsbuild-config-tooltip';
13
14
 
14
- 默认情况下,构建后的产物名称会包含 hash 值:
15
-
16
- ```bash
17
- dist/static/css/index.7879e19d.css
18
- dist/static/js/index.18a568e5.js
19
- ```
20
-
21
- 你可以将 `output.filenameHash` 设置为 false 来禁用这个行为:
22
-
23
- ```js
24
- export default {
25
- output: {
26
- filenameHash: false,
27
- },
28
- };
29
- ```
30
-
31
- 重新构建,产物的名称变为:
32
-
33
- ```bash
34
- dist/static/css/index.css
35
- dist/static/js/index.js
36
- ```
37
-
38
- 详细用法可参考 [Rsbuild - output.filenameHash](https://rsbuild.dev/zh/config/output/filename-hash)。
15
+ <RsbuildConig />
@@ -1,9 +1,54 @@
1
1
  ---
2
2
  title: filename
3
+ configName: output.filename
3
4
  ---
4
5
 
5
6
  # output.filename
6
7
 
7
- import Main from '@modern-js/builder-doc/docs/zh/config/output/filename.md';
8
+ - **类型:**
8
9
 
9
- <Main />
10
+ ```ts
11
+ type FilenameConfig = {
12
+ html?: string;
13
+ js?:
14
+ | string
15
+ | ((pathData: Rspack.PathData, assetInfo: Rspack.JsAssetInfo) => string);
16
+ css?: string;
17
+ svg?: string;
18
+ font?: string;
19
+ image?: string;
20
+ media?: string;
21
+ };
22
+ ```
23
+
24
+ - **默认值:**
25
+
26
+ ```js
27
+ // 开发模式构建
28
+ const devDefaultFilename = {
29
+ html: '[name].html',
30
+ js: '[name].js',
31
+ css: '[name].css',
32
+ svg: '[name].[contenthash:8].svg',
33
+ font: '[name].[contenthash:8][ext]',
34
+ image: '[name].[contenthash:8][ext]',
35
+ media: '[name].[contenthash:8][ext]',
36
+ };
37
+
38
+ // 生产模式构建
39
+ const prodDefaultFilename = {
40
+ html: '[name].html',
41
+ js: output.target === 'node' ? '[name].js' : '[name].[contenthash:8].js',
42
+ css: '[name].[contenthash:8].css',
43
+ svg: '[name].[contenthash:8].svg',
44
+ font: '[name].[contenthash:8][ext]',
45
+ image: '[name].[contenthash:8][ext]',
46
+ media: '[name].[contenthash:8][ext]',
47
+ };
48
+ ```
49
+
50
+ 设置构建产物的名称。
51
+
52
+ import RsbuildConig from '@site-docs/components/rsbuild-config-tooltip';
53
+
54
+ <RsbuildConig />
@@ -0,0 +1,15 @@
1
+ ---
2
+ title: injectStyles
3
+ configName: output.injectStyles
4
+ ---
5
+
6
+ # output.injectStyles
7
+
8
+ - **类型:** `boolean`
9
+ - **默认值:** `false`
10
+
11
+ 是否将 CSS 样式插入到 DOM 中。
12
+
13
+ import RsbuildConig from '@site-docs/components/rsbuild-config-tooltip';
14
+
15
+ <RsbuildConig />
@@ -0,0 +1,34 @@
1
+ ---
2
+ title: inlineScripts
3
+ configName: output.inlineScripts
4
+ ---
5
+
6
+ # output.inlineScripts
7
+
8
+ - **类型:**
9
+
10
+ ```ts
11
+ type InlineScriptsTest =
12
+ | RegExp
13
+ | ((params: { size: number; name: string }) => boolean);
14
+
15
+ type InlineScripts =
16
+ | boolean
17
+ | InlineScriptsTest
18
+ | {
19
+ enable?: boolean | 'auto';
20
+ test: InlineScriptsTest;
21
+ };
22
+ ```
23
+
24
+ - **默认值:** `false`
25
+
26
+ 用来控制是否用 `<script>` 标签将产物中的 script 文件(.js 文件)inline 到 HTML 中。
27
+
28
+ :::tip
29
+ 当使用约定式路由时,如果开启了这个选项,需要将 [output.splitRouteChunks](https://modernjs.dev/configure/app/output/splitRouteChunks.html) 设置为 false。
30
+ :::
31
+
32
+ import RsbuildConig from '@site-docs/components/rsbuild-config-tooltip';
33
+
34
+ <RsbuildConig />
@@ -0,0 +1,34 @@
1
+ ---
2
+ title: inlineStyles
3
+ configName: output.inlineStyles
4
+ ---
5
+
6
+ # output.inlineStyles
7
+
8
+ - **类型:**
9
+
10
+ ```ts
11
+ type InlineStylesTest =
12
+ | RegExp
13
+ | ((params: { size: number; name: string }) => boolean);
14
+
15
+ type InlineStyles =
16
+ | boolean
17
+ | InlineStylesTest
18
+ | {
19
+ enable?: boolean | 'auto';
20
+ test: InlineStylesTest;
21
+ };
22
+ ```
23
+
24
+ - **默认值:** `false`
25
+
26
+ 用来控制是否用 `<style>` 标签将产物中的 style 文件(.css 文件)inline 到 HTML 中。
27
+
28
+ :::tip
29
+ 当使用约定式路由时,如果开启了这个选项,需要将 [output.splitRouteChunks](https://modernjs.dev/configure/app/output/splitRouteChunks.html) 设置为 false。
30
+ :::
31
+
32
+ import RsbuildConig from '@site-docs/components/rsbuild-config-tooltip';
33
+
34
+ <RsbuildConig />
@@ -1,9 +1,23 @@
1
1
  ---
2
2
  title: legalComments
3
+ configName: output.legalComments
3
4
  ---
4
5
 
5
6
  # output.legalComments
6
7
 
7
- import Main from '@modern-js/builder-doc/docs/zh/config/output/legalComments.md';
8
+ - **类型:** `'linked' | 'inline' | 'none'`
9
+ - **默认值:** `'linked'`
8
10
 
9
- <Main />
11
+ 配置 legal comment 的处理方式。
12
+
13
+ legal comment 是 JS 或 CSS 文件中的一些特殊注释,这些注释包含 `@license` 或 `@preserve`,或是以 `//!` 或 `/*!` 开头。默认情况下,这些注释保留在输出文件中,因为这遵循了代码原作者的意图。
14
+
15
+ 你可以通过 `legalComments` 来配置相关行为:
16
+
17
+ - `linked`:将所有 legal comments 移至 .LEGAL.txt 文件并通过注释链接到它们。
18
+ - `inline`:保留所有 legal comments。
19
+ - `none`:移除所有 legal comments。
20
+
21
+ import RsbuildConig from '@site-docs/components/rsbuild-config-tooltip';
22
+
23
+ <RsbuildConig />
@@ -0,0 +1,27 @@
1
+ ---
2
+ title: minify
3
+ configName: output.minify
4
+ ---
5
+
6
+ # output.minify
7
+
8
+ - **类型:**
9
+
10
+ ```ts
11
+ type Minify =
12
+ | boolean
13
+ | {
14
+ js?: boolean;
15
+ jsOptions?: SwcJsMinimizerRspackPluginOptions;
16
+ css?: boolean;
17
+ cssOptions?: LightningCssMinimizerRspackPluginOptions;
18
+ };
19
+ ```
20
+
21
+ - **默认值:** `true`
22
+
23
+ 用于设置是否在生产模式下开启代码压缩,或是配置压缩工具的选项。
24
+
25
+ import RsbuildConig from '@site-docs/components/rsbuild-config-tooltip';
26
+
27
+ <RsbuildConig />
@@ -1,9 +1,27 @@
1
1
  ---
2
2
  title: overrideBrowserslist
3
+ configName: output.overrideBrowserslist
3
4
  ---
4
5
 
5
6
  # output.overrideBrowserslist
6
7
 
7
- import Main from '@modern-js/builder-doc/docs/zh/config/output/overrideBrowserslist.md';
8
+ - **类型:** `string[] | undefined`
9
+ - **默认值:**
8
10
 
9
- <Main />
11
+ ```ts
12
+ const defaultBrowserListMap: Record<RsbuildTarget, string[]> = {
13
+ web: ['> 0.01%', 'not dead', 'not op_mini all'],
14
+ node: ['node >= 14'],
15
+ 'web-worker': ['> 0.01%', 'not dead', 'not op_mini all'],
16
+ };
17
+ ```
18
+
19
+ 指定项目兼容的目标浏览器范围。
20
+
21
+ 该值会被 [SWC](https://github.com/swc-project/swc) 和 [autoprefixer](https://github.com/postcss/autoprefixer) 用来确定需要转换的 JavaScript 语法特性和需要添加的 CSS 浏览器前缀。
22
+
23
+ Modern.js 会优先使用项目根目录的 `.browserslistrc` 文件中的配置。
24
+
25
+ import RsbuildConig from '@site-docs/components/rsbuild-config-tooltip';
26
+
27
+ <RsbuildConig />
@@ -1,9 +1,19 @@
1
1
  ---
2
2
  title: polyfill
3
+ configName: output.polyfill
3
4
  ---
4
5
 
5
6
  # output.polyfill
6
7
 
7
- import Main from '@modern-js/builder-doc/docs/zh/config/output/polyfill.md';
8
+ - **类型:** `'entry' | 'usage' | 'ua' | 'off'`
9
+ - **默认值:** `'entry'`
8
10
 
9
- <Main />
11
+ 通过 `output.polyfill` 你可以配置 Polyfill 的注入方式。
12
+
13
+ import OutputPolyfillExtend from '@site-docs/components/output-polyfill-extend';
14
+
15
+ <OutputPolyfillExtend />
16
+
17
+ import RsbuildConig from '@site-docs/components/rsbuild-config-tooltip';
18
+
19
+ <RsbuildConig />
@@ -0,0 +1,30 @@
1
+ ---
2
+ title: sourceMap
3
+ configName: output.sourceMap
4
+ ---
5
+
6
+ # output.sourceMap
7
+
8
+ - **类型:**
9
+
10
+ ```ts
11
+ type SourceMap = {
12
+ js?: Rspack.Configuration['devtool'];
13
+ css?: boolean;
14
+ };
15
+ ```
16
+
17
+ - **默认值:**
18
+
19
+ ```ts
20
+ const defaultSourceMap = {
21
+ js: isDev ? 'cheap-module-source-map' : false,
22
+ css: false,
23
+ };
24
+ ```
25
+
26
+ 用于设置是否生成 source map 文件,以及生成哪一种格式的 source map。
27
+
28
+ import RsbuildConig from '@site-docs/components/rsbuild-config-tooltip';
29
+
30
+ <RsbuildConig />
@@ -4,7 +4,7 @@ title: ssg
4
4
 
5
5
  # output.ssg
6
6
 
7
- - **类型:** `boolean` | `object`
7
+ - **类型:** `boolean | object`
8
8
  - **默认值:** `undefined`
9
9
 
10
10
  开启应用 SSG 功能的配置
@@ -66,11 +66,13 @@ export default defineConfig({
66
66
  ### 配置类型
67
67
 
68
68
  ```ts
69
- type SSGRouteOptions = string | {
70
- url: string;
71
- params?: Record<string, any>[];
72
- headers?: Record<string, any>;
73
- };
69
+ type SSGRouteOptions =
70
+ | string
71
+ | {
72
+ url: string;
73
+ params?: Record<string, any>[];
74
+ headers?: Record<string, any>;
75
+ };
74
76
 
75
77
  type SSGOptions = {
76
78
  preventDefault?: string[];
@@ -90,20 +92,22 @@ export default defineConfig({
90
92
  output: {
91
93
  ssg: {
92
94
  routes: [
93
- '/',
94
- '/about',
95
+ '/',
96
+ '/about',
95
97
  {
96
98
  url: '/user/:id',
97
99
  headers: {
98
- cookies: "name=modernjs"
100
+ cookies: 'name=modernjs',
99
101
  },
100
- params: [{
101
- id: 'modernjs',
102
- }],
103
- }
102
+ params: [
103
+ {
104
+ id: 'modernjs',
105
+ },
106
+ ],
107
+ },
104
108
  ],
105
- }
106
- }
109
+ },
110
+ },
107
111
  });
108
112
  ```
109
113
 
@@ -4,6 +4,31 @@ title: svgDefaultExport
4
4
 
5
5
  # output.svgDefaultExport
6
6
 
7
- import Main from '@modern-js/builder-doc/docs/zh/config/output/svgDefaultExport.md';
7
+ - **类型:** `'url' | 'component'`
8
+ - **默认值:** `'url'`
8
9
 
9
- <Main />
10
+ `output.svgDefaultExport` 可以用来配置 SVG 文件的默认导出。
11
+
12
+ 当 `output.svgDefaultExport` 配置为 `url` 时,SVG 文件的默认导出是文件的 URL。例如:
13
+
14
+ ```js
15
+ import logo from './logo.svg';
16
+
17
+ console.log(logo); // => 资源 url
18
+ ```
19
+
20
+ 当 `output.svgDefaultExport` 配置为 `component` 时,SVG 文件的默认导出是文件的 React 组件。例如:
21
+
22
+ ```js
23
+ import Logo from './logo.svg';
24
+
25
+ console.log(Logo); // => React 组件
26
+ ```
27
+
28
+ 此时,你也可以通过指定 `?url` 的 query 来导入 url,比如:
29
+
30
+ ```js
31
+ import logo from './logo.svg?url';
32
+
33
+ console.log(logo); // => 资源 url
34
+ ```
@@ -4,6 +4,81 @@ title: buildCache
4
4
 
5
5
  # performance.buildCache
6
6
 
7
- import Main from '@modern-js/builder-doc/docs/zh/config/performance/buildCache.md';
7
+ - **类型:**
8
8
 
9
- <Main />
9
+ ```ts
10
+ type BuildCacheConfig =
11
+ | {
12
+ /**
13
+ * webpack 文件缓存系统的缓存目录
14
+ */
15
+ cacheDirectory?: string;
16
+ /**
17
+ * 根据 cacheDigest 内容设置不同的缓存名称
18
+ */
19
+ cacheDigest?: Array<string | undefined>;
20
+ }
21
+ | boolean;
22
+ ```
23
+
24
+ - **默认值:**
25
+
26
+ ```js
27
+ const defaultBuildCacheConfig = {
28
+ cacheDirectory: './node_modules/.cache/webpack',
29
+ };
30
+ ```
31
+
32
+ - **打包工具:** `仅支持 webpack`
33
+
34
+ 控制 Modern.js 在构建过程中的缓存行为。
35
+
36
+ Modern.js 默认会开启构建缓存来提升二次构建的速度,并默认把生成的缓存文件写到 `./node_modules/.cache/webpack` 目录下。
37
+
38
+ 你可以通过 `buildCache` 配置缓存路径,比如:
39
+
40
+ ```js
41
+ export default {
42
+ performance: {
43
+ buildCache: {
44
+ cacheDirectory: './node_modules/.custom_cache/webpack',
45
+ },
46
+ },
47
+ };
48
+ ```
49
+
50
+ 如果不希望缓存,你也可以将 `buildCache` 置为 `false` 将其禁用掉:
51
+
52
+ ```js
53
+ export default {
54
+ performance: {
55
+ buildCache: false,
56
+ },
57
+ };
58
+ ```
59
+
60
+ ### cacheDigest
61
+
62
+ `cacheDigest` 用来添加一些会对构建结果产生影响的环境变量。Modern.js 将根据 `cacheDigest` 内容和当前构建模式来设置缓存名称,来确保不同的 `cacheDigest` 可以命中不同的缓存。
63
+
64
+ #### 示例
65
+
66
+ 当前项目需要根据不同的 `APP_ID` 来设置不同的 extensions。默认情况下,由于当前项目的代码 & 配置 & 依赖未发生变化,会命中之前的缓存。
67
+ 通过将 `APP_ID` 添加到 `cacheDigest` 中,在 `APP_ID` 变化时会去查找不同的缓存结果,从而避免命中不符合预期的缓存结果。
68
+
69
+ ```js
70
+ export default {
71
+ tools: {
72
+ bundlerChain: chain => {
73
+ if (process.env.APP_ID === 'xxx') {
74
+ chain.resolve.extensions.prepend('.ttp.ts');
75
+ }
76
+ },
77
+ },
78
+ performance: {
79
+ buildCache: {
80
+ cacheDigest: [process.env.APP_ID],
81
+ },
82
+ },
83
+ };
84
+ ```