@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,247 @@ title: webpackChain
4
4
 
5
5
  # tools.webpackChain
6
6
 
7
- import Main from '@modern-js/builder-doc/docs/zh/config/tools/webpackChain.md';
7
+ - **类型:** `Function | undefined`
8
+ - **默认值:** `undefined`
9
+ - **打包工具:** `仅支持 webpack`
8
10
 
9
- <Main />
11
+ 你可以通过 `tools.webpackChain` 来修改默认的 webpack 配置,它的值为 `Function` 类型,接收两个参数:
12
+
13
+ - 第一个参数为 `webpack-chain` 对象实例,你可以通过这个实例来修改默认的 webpack 配置。
14
+ - 第二个参数为一个工具集合,包括`env`、`isProd`、`CHAIN_ID` 等。
15
+
16
+ 相比于 `tools.webpack`,**webpack-chain 不仅支持链式调用,而且能够基于别名来定位到内置的 Rule 或 Plugin,从而实现精准的配置修改**。我们推荐使用 `tools.webpackChain` 来代替 `tools.webpack`。
17
+
18
+ > `tools.webpackChain` 的执行时机早于 tools.webpack,因此会被 `tools.webpack` 中的修改所覆盖。
19
+
20
+ ### 工具集合
21
+
22
+ #### env
23
+
24
+ - **类型:** `'development' | 'production' | 'test'`
25
+
26
+ 通过 env 参数可以判断当前环境为 development、production 还是 test。比如:
27
+
28
+ ```js
29
+ export default {
30
+ tools: {
31
+ webpackChain: (chain, { env }) => {
32
+ if (env === 'development') {
33
+ chain.devtool('cheap-module-eval-source-map');
34
+ }
35
+ },
36
+ },
37
+ };
38
+ ```
39
+
40
+ #### isProd
41
+
42
+ - **类型:** `boolean`
43
+
44
+ 通过 isProd 参数可以判断当前环境是否为 production。比如:
45
+
46
+ ```js
47
+ export default {
48
+ tools: {
49
+ webpackChain: (chain, { isProd }) => {
50
+ if (isProd) {
51
+ chain.devtool('source-map');
52
+ }
53
+ },
54
+ },
55
+ };
56
+ ```
57
+
58
+ #### target
59
+
60
+ - **类型:** `'web' | 'node' | 'modern-web' | 'web-worker'`
61
+
62
+ 通过 target 参数可以判断当前构建的目标运行时环境。比如:
63
+
64
+ ```js
65
+ export default {
66
+ tools: {
67
+ webpackChain: (chain, { target }) => {
68
+ if (target === 'node') {
69
+ // ...
70
+ }
71
+ },
72
+ },
73
+ };
74
+ ```
75
+
76
+ #### isServer
77
+
78
+ - **类型:** `boolean`
79
+
80
+ 判断当前构建的目标运行时环境是否为 `node`,等价于 `target === 'node'`。
81
+
82
+ ```js
83
+ export default {
84
+ tools: {
85
+ webpackChain: (chain, { isServer }) => {
86
+ if (isServer) {
87
+ // ...
88
+ }
89
+ },
90
+ },
91
+ };
92
+ ```
93
+
94
+ #### isWebWorker
95
+
96
+ - **类型:** `boolean`
97
+
98
+ 判断当前构建的目标运行时环境是否为 `web-worker`,等价于 `target === 'web-worker'`。
99
+
100
+ ```js
101
+ export default {
102
+ tools: {
103
+ webpackChain: (chain, { isWebWorker }) => {
104
+ if (isWebWorker) {
105
+ // ...
106
+ }
107
+ },
108
+ },
109
+ };
110
+ ```
111
+
112
+ #### webpack
113
+
114
+ - **类型:** `typeof import('webpack')`
115
+
116
+ 通过这个参数你可以拿到 webpack 实例。比如:
117
+
118
+ ```js
119
+ export default {
120
+ tools: {
121
+ webpackChain: (chain, { webpack }) => {
122
+ chain.plugin('my-progress').use(webpack.ProgressPlugin);
123
+ },
124
+ },
125
+ };
126
+ ```
127
+
128
+ #### HtmlWebpackPlugin
129
+
130
+ - **类型:** `typeof import('html-webpack-plugin')`
131
+
132
+ 通过这个参数你可以拿到 HtmlWebpackPlugin 实例。
133
+
134
+ ```js
135
+ export default {
136
+ tools: {
137
+ webpackChain: (chain, { HtmlWebpackPlugin }) => {
138
+ console.log(HtmlWebpackPlugin);
139
+ },
140
+ },
141
+ };
142
+ ```
143
+
144
+ #### CHAIN_ID
145
+
146
+ Modern.js 中预先定义了一些常用的 Chain ID,你可以通过这些 ID 来定位到内置的 Rule 或 Plugin。
147
+
148
+ :::tip
149
+ 请留意,下列的一部分 Rule 或 Plugin 并不是默认存在的,当你开启特定配置项、或是注册某些插件后,它们才会被包含在 webpack 配置中。
150
+
151
+ 比如,`RULE.STYLUS` 仅在注册了 Stylus 插件后才会存在。
152
+ :::
153
+
154
+ #### CHAIN_ID.RULE
155
+
156
+ | ID | 描述 |
157
+ | ------------- | --------------------------------------------------------------------------------------------- |
158
+ | `RULE.MJS` | 处理 `mjs` 的规则 |
159
+ | `RULE.JS` | 处理 `js` 的规则 |
160
+ | `RULE.TS` | 处理 `ts` 的规则 |
161
+ | `RULE.CSS` | 处理 `css` 的规则 |
162
+ | `RULE.LESS` | 处理 `less` 的规则 |
163
+ | `RULE.SASS` | 处理 `sass` 的规则 |
164
+ | `RULE.STYLUS` | 处理 `stylus` 的规则(依赖 [Stylus 插件](https://rsbuild.dev/zh/plugins/list/plugin-stylus)) |
165
+ | `RULE.SVG` | Rule for `svg` |
166
+ | `RULE.PUG` | 处理 `pug` 的规则 |
167
+ | `RULE.TOML` | 处理 `toml` 的规则 |
168
+ | `RULE.YAML` | 处理 `yaml` 的规则 |
169
+ | `RULE.WASM` | 处理 `wasm` 的规则 |
170
+ | `RULE.NODE` | 处理 `node` 的规则 |
171
+ | `RULE.FONT` | 处理字体的规则 |
172
+ | `RULE.IMAGE` | 处理图片的规则 |
173
+ | `RULE.MEDIA` | 处理媒体资源的规则 |
174
+
175
+ #### CHAIN_ID.ONE_OF
176
+
177
+ 通过 `ONE_OF.XXX` 可以匹配到规则数组中的某一类规则。
178
+
179
+ | ID | 描述 |
180
+ | ------------------- | --------------------------------------------------- |
181
+ | `ONE_OF.SVG` | 处理 SVG 的规则,在 data URI 和单独文件之间自动选择 |
182
+ | `ONE_OF.SVG_URL` | 处理 SVG 的规则,输出为单独文件 |
183
+ | `ONE_OF.SVG_INLINE` | 处理 SVG 的规则,作为 data URI 内联到 bundle 中 |
184
+ | `ONE_OF.SVG_ASSETS` | 处理 SVG 的规则,在 data URI 和单独文件之间自动选择 |
185
+
186
+ #### CHAIN_ID.USE
187
+
188
+ 通过 `USE.XXX` 可以匹配到对应的 loader。
189
+
190
+ | ID | 描述 |
191
+ | --------------------------------- | ------------------------------------- |
192
+ | `USE.TS` | 对应 `ts-loader` |
193
+ | `USE.CSS` | 对应 `css-loader` |
194
+ | `USE.LESS` | 对应 `less-loader` |
195
+ | `USE.SASS` | 对应 `sass-loader` |
196
+ | `USE.STYLUS` | 对应 `stylus-loader` |
197
+ | `USE.PUG` | 对应 `pug-loader` |
198
+ | `USE.VUE` | 对应 `vue-loader` |
199
+ | `USE.TOML` | 对应 `toml-loader` |
200
+ | `USE.YAML` | 对应 `yaml-loader` |
201
+ | `USE.NODE` | 对应 `node-loader` |
202
+ | `USE.URL` | 对应 `url-loader` |
203
+ | `USE.SVGR` | 对应 `@svgr/webpack` |
204
+ | `USE.BABEL` | 对应 `babel-loader` |
205
+ | `USE.STYLE` | 对应 `style-loader` |
206
+ | `USE.POSTCSS` | 对应 `postcss-loader` |
207
+ | `USE.CSS_MODULES_TS` | 对应 `css-modules-typescript-loader` |
208
+ | `USE.MINI_CSS_EXTRACT` | 对应 `mini-css-extract-plugin.loader` |
209
+ | `USE.RESOLVE_URL_LOADER_FOR_SASS` | 对应 `resolve-url-loader` |
210
+
211
+ #### CHAIN_ID.PLUGIN
212
+
213
+ 通过 `PLUGIN.XXX` 可以匹配到对应的 plugin。
214
+
215
+ | ID | 描述 |
216
+ | ------------------------------ | ---------------------------------------------------------------------------------- |
217
+ | `PLUGIN.HMR` | 对应 `HotModuleReplacementPlugin` |
218
+ | `PLUGIN.COPY` | 对应 `CopyWebpackPlugin` |
219
+ | `PLUGIN.HTML` | 对应 `HtmlWebpackPlugin`,使用时需要拼接 entry 名称:`${PLUGIN.HTML}-${entryName}` |
220
+ | `PLUGIN.DEFINE` | 对应 `DefinePlugin` |
221
+ | `PLUGIN.IGNORE` | 对应 `IgnorePlugin` |
222
+ | `PLUGIN.BANNER` | 对应 `BannerPlugin` |
223
+ | `PLUGIN.PROGRESS` | 对应 `Webpackbar` |
224
+ | `PLUGIN.APP_ICON` | 对应 `AppIconPlugin` |
225
+ | `PLUGIN.MANIFEST` | 对应 `WebpackManifestPlugin` |
226
+ | `PLUGIN.TS_CHECKER` | 对应 `ForkTsCheckerWebpackPlugin` |
227
+ | `PLUGIN.INLINE_HTML` | 对应 `InlineChunkHtmlPlugin` |
228
+ | `PLUGIN.BUNDLE_ANALYZER` | 对应 `WebpackBundleAnalyzer` |
229
+ | `PLUGIN.MINI_CSS_EXTRACT` | 对应 `MiniCssExtractPlugin` |
230
+ | `PLUGIN.VUE_LOADER_PLUGIN` | 对应 `VueLoaderPlugin` |
231
+ | `PLUGIN.REACT_FAST_REFRESH` | 对应 `ReactFastRefreshPlugin` |
232
+ | `PLUGIN.NODE_POLYFILL_PROVIDE` | 对应处理 node polyfill 的 `ProvidePlugin` |
233
+ | `PLUGIN.SUBRESOURCE_INTEGRITY` | 对应 `webpack-subresource-integrity` |
234
+ | `PLUGIN.ASSETS_RETRY` | 对应 webpack 静态资源重试插件 `WebpackAssetsRetryPlugin` |
235
+ | `PLUGIN.AUTO_SET_ROOT_SIZE` | 对应自动设置根字体大小插件 `AutoSetRootSizePlugin` |
236
+
237
+ #### CHAIN_ID.MINIMIZER
238
+
239
+ 通过 `MINIMIZER.XXX` 可以匹配到对应的压缩工具。
240
+
241
+ | ID | 描述 |
242
+ | ------------------- | -------------------------------- |
243
+ | `MINIMIZER.JS` | 对应 `TerserWebpackPlugin` |
244
+ | `MINIMIZER.CSS` | 对应 `CssMinimizerWebpackPlugin` |
245
+ | `MINIMIZER.ESBUILD` | 对应 `ESBuildPlugin` |
246
+ | `MINIMIZER.SWC` | 对应 `SwcWebpackPlugin` |
247
+
248
+ ### 使用示例
249
+
250
+ 使用示例可参考:[WebpackChain 使用示例](https://modernjs.dev/builder/guide/advanced/custom-webpack-config.html#%E4%BD%BF%E7%94%A8-webpack-chain)。
@@ -4,6 +4,299 @@ title: webpack
4
4
 
5
5
  # tools.webpack
6
6
 
7
- import Main from '@modern-js/builder-doc/docs/zh/config/tools/webpack.md';
7
+ - **类型:** `Object | Function | undefined`
8
+ - **默认值:** `undefined`
9
+ - **打包工具:** `仅支持 webpack`
8
10
 
9
- <Main />
11
+ `tools.webpack` 选项用于配置原生的 [webpack](https://webpack.js.org/)。
12
+
13
+ > `tools.bundlerChain` 同样可以修改 webpack 配置,并且功能更加强大,建议优先使用 `tools.bundlerChain`。
14
+
15
+ ### Object 类型
16
+
17
+ `tools.webpack` 可以配置为一个对象,这个对象将会和内置的 webpack 配置通过 [webpack-merge](https://github.com/survivejs/webpack-merge) 进行深层合并。
18
+
19
+ 比如添加 `resolve.alias` 配置:
20
+
21
+ ```js
22
+ export default {
23
+ tools: {
24
+ webpack: {
25
+ resolve: {
26
+ alias: {
27
+ '@util': 'src/util',
28
+ },
29
+ },
30
+ },
31
+ },
32
+ };
33
+ ```
34
+
35
+ ### Function 类型
36
+
37
+ `tools.webpack` 也可以配置为一个函数,这个函数的第一个入参为内置的 webpack 配置对象,你可以对这个对象进行修改,然后返回一份新的配置。比如:
38
+
39
+ ```js
40
+ export default {
41
+ tools: {
42
+ webpack: config => {
43
+ config.resolve.alias['@util'] = 'src/util';
44
+ return config;
45
+ },
46
+ },
47
+ };
48
+ ```
49
+
50
+ :::tip
51
+ `tools.webpack` 函数返回的对象会直接作为最终使用的 webpack 配置,不会再与内置的 webpack 配置进行合并。
52
+ :::
53
+
54
+ ### 工具集合
55
+
56
+ 这个函数的第二个参数是一个对象,包含了一些工具函数和属性,详情如下:
57
+
58
+ #### env
59
+
60
+ - **类型:** `'development' | 'production' | 'test'`
61
+
62
+ 通过 env 参数可以判断当前环境为 development、production 还是 test。比如:
63
+
64
+ ```js
65
+ export default {
66
+ tools: {
67
+ webpack: (config, { env }) => {
68
+ if (env === 'development') {
69
+ config.devtool = 'cheap-module-eval-source-map';
70
+ }
71
+ return config;
72
+ },
73
+ },
74
+ };
75
+ ```
76
+
77
+ #### isProd
78
+
79
+ - **类型:** `boolean`
80
+
81
+ 通过 isProd 参数可以判断当前环境是否为 production。比如:
82
+
83
+ ```js
84
+ export default {
85
+ tools: {
86
+ webpack: (config, { isProd }) => {
87
+ if (isProd) {
88
+ config.devtool = 'source-map';
89
+ }
90
+ return config;
91
+ },
92
+ },
93
+ };
94
+ ```
95
+
96
+ #### target
97
+
98
+ - **类型:** `'web' | 'node' | 'modern-web' | 'web-worker'`
99
+
100
+ 通过 target 参数可以判断当前构建的目标运行时环境。比如:
101
+
102
+ ```js
103
+ export default {
104
+ tools: {
105
+ webpack: (config, { target }) => {
106
+ if (target === 'node') {
107
+ // ...
108
+ }
109
+ return config;
110
+ },
111
+ },
112
+ };
113
+ ```
114
+
115
+ #### isServer
116
+
117
+ - **类型:** `boolean`
118
+
119
+ 判断当前构建的目标运行时环境是否为 `node`,等价于 `target === 'node'`。
120
+
121
+ ```js
122
+ export default {
123
+ tools: {
124
+ webpack: (config, { isServer }) => {
125
+ if (isServer) {
126
+ // ...
127
+ }
128
+ return config;
129
+ },
130
+ },
131
+ };
132
+ ```
133
+
134
+ #### isWebWorker
135
+
136
+ - **类型:** `boolean`
137
+
138
+ 判断当前构建的目标运行时环境是否为 `web-worker`,等价于 `target === 'web-worker'`。
139
+
140
+ ```js
141
+ export default {
142
+ tools: {
143
+ webpack: (config, { isWebWorker }) => {
144
+ if (isWebWorker) {
145
+ // ...
146
+ }
147
+ return config;
148
+ },
149
+ },
150
+ };
151
+ ```
152
+
153
+ #### webpack
154
+
155
+ - **类型:** `typeof import('webpack')`
156
+
157
+ 通过这个参数你可以拿到 webpack 实例。比如:
158
+
159
+ ```js
160
+ export default {
161
+ tools: {
162
+ webpack: (config, { webpack }) => {
163
+ config.plugins.push(new webpack.ProgressPlugin());
164
+ return config;
165
+ },
166
+ },
167
+ };
168
+ ```
169
+
170
+ #### HtmlWebpackPlugin
171
+
172
+ - **类型:** `typeof import('html-webpack-plugin')`
173
+
174
+ 通过这个参数你可以拿到 HtmlWebpackPlugin 实例。
175
+
176
+ ```js
177
+ export default {
178
+ tools: {
179
+ webpack: (chain, { HtmlWebpackPlugin }) => {
180
+ console.log(HtmlWebpackPlugin);
181
+ },
182
+ },
183
+ };
184
+ ```
185
+
186
+ #### addRules
187
+
188
+ - **类型:** `(rules: RuleSetRule | RuleSetRule[]) => void`
189
+
190
+ 添加额外的 [webpack rules](https://webpack.js.org/configuration/module/#modulerules)。
191
+
192
+ 示例:
193
+
194
+ ```ts
195
+ export default {
196
+ tools: {
197
+ webpack: (config, { addRules }) => {
198
+ // 添加单条规则
199
+ addRules({
200
+ test: /\.foo/,
201
+ loader: require.resolve('foo-loader'),
202
+ });
203
+
204
+ // 以数组形式添加多条规则
205
+ addRules([
206
+ {
207
+ test: /\.foo/,
208
+ loader: require.resolve('foo-loader'),
209
+ },
210
+ {
211
+ test: /\.bar/,
212
+ loader: require.resolve('bar-loader'),
213
+ },
214
+ ]);
215
+ },
216
+ },
217
+ };
218
+ ```
219
+
220
+ #### prependPlugins
221
+
222
+ - **类型:** `(plugins: WebpackPluginInstance | WebpackPluginInstance[]) => void`
223
+
224
+ 在内部 webpack 插件数组头部添加额外的插件,数组头部的插件会优先执行。
225
+
226
+ ```ts
227
+ export default {
228
+ tools: {
229
+ webpack: (config, { prependPlugins, webpack }) => {
230
+ // 添加单个插件
231
+ prependPlugins(
232
+ new webpack.BannerPlugin({
233
+ banner: 'hello world!',
234
+ }),
235
+ );
236
+
237
+ // 以数组形式添加多个插件
238
+ prependPlugins([new PluginA(), new PluginB()]);
239
+ },
240
+ },
241
+ };
242
+ ```
243
+
244
+ #### appendPlugins
245
+
246
+ - **类型:** `(plugins: WebpackPluginInstance | WebpackPluginInstance[]) => void`
247
+
248
+ 在内部 webpack 插件数组尾部添加额外的插件,数组尾部的插件会在最后执行。
249
+
250
+ ```ts
251
+ export default {
252
+ tools: {
253
+ webpack: (config, { appendPlugins, webpack }) => {
254
+ // 添加单个插件
255
+ appendPlugins([
256
+ new webpack.BannerPlugin({
257
+ banner: 'hello world!',
258
+ }),
259
+ ]);
260
+
261
+ // 以数组形式添加多个插件
262
+ appendPlugins([new PluginA(), new PluginB()]);
263
+ },
264
+ },
265
+ };
266
+ ```
267
+
268
+ #### removePlugin
269
+
270
+ - **类型:** `(name: string) => void`
271
+
272
+ 删除内部的 webpack 插件,参数为该插件的 `constructor.name`。
273
+
274
+ 例如,删除内部的 [fork-ts-checker-webpack-plugin](https://github.com/TypeStrong/fork-ts-checker-webpack-plugin):
275
+
276
+ ```ts
277
+ export default {
278
+ tools: {
279
+ webpack: (config, { removePlugin }) => {
280
+ removePlugin('ForkTsCheckerWebpackPlugin');
281
+ },
282
+ },
283
+ };
284
+ ```
285
+
286
+ #### mergeConfig
287
+
288
+ - **类型:** `(...configs: WebpackConfig[]) => WebpackConfig`
289
+
290
+ 用于合并多份 webpack 配置,等价于 [webpack-merge](https://github.com/survivejs/webpack-merge)。
291
+
292
+ ```ts
293
+ export default {
294
+ tools: {
295
+ webpack: (config, { mergeConfig }) => {
296
+ return mergeConfig(config, {
297
+ devtool: 'eval',
298
+ });
299
+ },
300
+ },
301
+ };
302
+ ```
@@ -24,11 +24,6 @@
24
24
  "name": "topic-detail",
25
25
  "label": "topic"
26
26
  },
27
- {
28
- "type": "dir",
29
- "name": "rsbuild-plugins",
30
- "label": "构建插件"
31
- },
32
27
  {
33
28
  "type": "dir",
34
29
  "name": "troubleshooting",
@@ -6,13 +6,15 @@
6
6
  "label": "use-bff",
7
7
  "collapsed": true
8
8
  },
9
- "code-split",
9
+ {
10
+ "type": "dir",
11
+ "name": "page-performance",
12
+ "label": "page-performance",
13
+ "collapsed": true
14
+ },
15
+ "build-performance",
10
16
  "compatibility",
11
- "eslint",
12
17
  "low-level",
13
18
  "source-build",
14
- "build-performance",
15
- "inline-assets",
16
- "optimize-bundle",
17
19
  "web-server"
18
20
  ]
@@ -1 +1 @@
1
- ["function", "type", "frameworks", "sdk"]
1
+ ["function", "frameworks", "extend-server", "sdk"]