@modern-js/main-doc 2.60.0 → 2.60.1
Sign up to get free protection for your applications and to get access to all the features.
- package/docs/en/apis/app/commands.mdx +0 -16
- package/docs/en/community/contributing-guide.mdx +0 -1
- package/docs/en/components/builder.mdx +3 -0
- package/docs/en/components/bundler.mdx +3 -0
- package/docs/en/components/enableSwc.mdx +17 -0
- package/docs/en/components/esbuild.mdx +3 -0
- package/docs/en/components/micro-frontend.mdx +6 -0
- package/docs/en/components/module-federation.mdx +7 -0
- package/docs/en/components/nodeVersion.mdx +26 -0
- package/docs/en/components/output-asset-prefix-extend.mdx +0 -0
- package/docs/en/components/output-polyfill-extend.mdx +1 -0
- package/docs/en/components/prerequisites.mdx +1 -1
- package/docs/en/components/rsbuild-config-tooltip.mdx +5 -0
- package/docs/en/components/rsbuild.mdx +3 -0
- package/docs/en/components/rspack.mdx +3 -0
- package/docs/en/components/rspackPrecautions.mdx +6 -0
- package/docs/en/components/rspackTip.mdx +7 -0
- package/docs/en/components/swc.mdx +3 -0
- package/docs/en/configure/app/dev/asset-prefix.mdx +12 -2
- package/docs/en/configure/app/dev/before-start-url.mdx +14 -2
- package/docs/en/configure/app/dev/client.mdx +20 -16
- package/docs/en/configure/app/dev/hmr.mdx +8 -2
- package/docs/en/configure/app/dev/host.mdx +15 -2
- package/docs/en/configure/app/dev/https.mdx +71 -2
- package/docs/en/configure/app/dev/live-reload.mdx +3 -15
- package/docs/en/configure/app/dev/port.mdx +18 -2
- package/docs/en/configure/app/dev/progress-bar.mdx +17 -2
- package/docs/en/configure/app/dev/setup-middlewares.mdx +25 -39
- package/docs/en/configure/app/dev/start-url.mdx +46 -2
- package/docs/en/configure/app/dev/watch-files.mdx +5 -39
- package/docs/en/configure/app/dev/write-to-disk.mdx +4 -27
- package/docs/en/configure/app/experiments/lazy-compilation.mdx +84 -2
- package/docs/en/configure/app/experiments/source-build.mdx +28 -3
- package/docs/en/configure/app/html/app-icon.mdx +48 -2
- package/docs/en/configure/app/html/crossorigin.mdx +8 -2
- package/docs/en/configure/app/html/disable-html-folder.mdx +35 -2
- package/docs/en/configure/app/html/favicon-by-entries.mdx +29 -2
- package/docs/en/configure/app/html/favicon.mdx +14 -2
- package/docs/en/configure/app/html/inject-by-entries.mdx +29 -2
- package/docs/en/configure/app/html/inject.mdx +8 -2
- package/docs/en/configure/app/html/meta-by-entries.mdx +41 -2
- package/docs/en/configure/app/html/meta.mdx +22 -2
- package/docs/en/configure/app/html/mount-id.mdx +8 -2
- package/docs/en/configure/app/html/script-loading.mdx +8 -2
- package/docs/en/configure/app/html/tags-by-entries.mdx +37 -2
- package/docs/en/configure/app/html/tags.mdx +13 -2
- package/docs/en/configure/app/html/template-by-entries.mdx +26 -2
- package/docs/en/configure/app/html/template-parameters-by-entries.mdx +28 -2
- package/docs/en/configure/app/html/template-parameters.mdx +31 -2
- package/docs/en/configure/app/html/template.mdx +8 -2
- package/docs/en/configure/app/html/title-by-entries.mdx +30 -2
- package/docs/en/configure/app/html/title.mdx +16 -2
- package/docs/en/configure/app/output/asset-prefix.mdx +12 -2
- package/docs/en/configure/app/output/assets-retry.mdx +72 -2
- package/docs/en/configure/app/output/charset.mdx +8 -2
- package/docs/en/configure/app/output/clean-dist-path.mdx +13 -2
- package/docs/en/configure/app/output/convert-to-rem.mdx +76 -2
- package/docs/en/configure/app/output/copy.mdx +5 -2
- package/docs/en/configure/app/output/css-module-local-ident-name.mdx +14 -2
- package/docs/en/configure/app/output/css-modules.mdx +46 -2
- package/docs/en/configure/app/output/data-uri-limit.mdx +24 -2
- package/docs/en/configure/app/output/disable-css-extract.mdx +9 -2
- package/docs/en/configure/app/output/disable-css-module-extension.mdx +52 -2
- package/docs/en/configure/app/output/disable-filename-hash.mdx +9 -2
- package/docs/en/configure/app/output/disable-inline-runtime-chunk.mdx +38 -2
- package/docs/en/configure/app/output/disable-minimize.mdx +7 -2
- package/docs/en/configure/app/output/disable-source-map.mdx +24 -2
- package/docs/en/configure/app/output/disable-svgr.mdx +13 -2
- package/docs/en/configure/app/output/disable-ts-checker.mdx +46 -2
- package/docs/en/configure/app/output/dist-path.mdx +39 -2
- package/docs/en/configure/app/output/enable-asset-fallback.mdx +29 -2
- package/docs/en/configure/app/output/enable-asset-manifest.mdx +33 -2
- package/docs/en/configure/app/output/enable-css-module-tsdeclaration.mdx +25 -2
- package/docs/en/configure/app/output/enable-inline-scripts.mdx +15 -2
- package/docs/en/configure/app/output/enable-inline-styles.mdx +15 -2
- package/docs/en/configure/app/output/enable-latest-decorators.mdx +7 -2
- package/docs/en/configure/app/output/externals.mdx +18 -2
- package/docs/en/configure/app/output/filename-hash.mdx +3 -27
- package/docs/en/configure/app/output/filename.mdx +47 -2
- package/docs/en/configure/app/output/inject-styles.mdx +15 -0
- package/docs/en/configure/app/output/inline-scripts.mdx +34 -0
- package/docs/en/configure/app/output/inline-styles.mdx +34 -0
- package/docs/en/configure/app/output/legal-comments.mdx +16 -2
- package/docs/en/configure/app/output/minify.mdx +27 -0
- package/docs/en/configure/app/output/override-browserslist.mdx +18 -2
- package/docs/en/configure/app/output/polyfill.mdx +12 -2
- package/docs/en/configure/app/output/source-map.mdx +30 -0
- package/docs/en/configure/app/output/ssg.mdx +20 -17
- package/docs/en/configure/app/output/svg-default-export.mdx +27 -2
- package/docs/en/configure/app/performance/build-cache.mdx +78 -2
- package/docs/en/configure/app/performance/bundle-analyze.mdx +18 -2
- package/docs/en/configure/app/performance/chunk-split.mdx +38 -2
- package/docs/en/configure/app/performance/dns-prefetch.mdx +13 -2
- package/docs/en/configure/app/performance/preconnect.mdx +14 -2
- package/docs/en/configure/app/performance/prefetch.mdx +19 -2
- package/docs/en/configure/app/performance/preload.mdx +21 -2
- package/docs/en/configure/app/performance/print-file-size.mdx +38 -2
- package/docs/en/configure/app/performance/profile.mdx +8 -2
- package/docs/en/configure/app/performance/remove-console.mdx +8 -2
- package/docs/en/configure/app/performance/remove-moment-locale.mdx +8 -2
- package/docs/en/configure/app/performance/transform-lodash.mdx +42 -2
- package/docs/en/configure/app/plugins.mdx +1 -1
- package/docs/en/configure/app/security/check-syntax.mdx +66 -2
- package/docs/en/configure/app/security/nonce.mdx +13 -2
- package/docs/en/configure/app/security/sri.mdx +19 -2
- package/docs/en/configure/app/server/port.mdx +5 -0
- package/docs/en/configure/app/server/ssr.mdx +10 -9
- package/docs/en/configure/app/source/alias-strategy.mdx +8 -2
- package/docs/en/configure/app/source/alias.mdx +17 -2
- package/docs/en/configure/app/source/config-dir.mdx +1 -1
- package/docs/en/configure/app/source/decorators.mdx +8 -21
- package/docs/en/configure/app/source/define.mdx +14 -2
- package/docs/en/configure/app/source/enable-async-entry.mdx +1 -1
- package/docs/en/configure/app/source/entries-dir.mdx +1 -1
- package/docs/en/configure/app/source/exclude.mdx +8 -2
- package/docs/en/configure/app/source/global-vars.mdx +103 -2
- package/docs/en/configure/app/source/include.mdx +19 -2
- package/docs/en/configure/app/source/mainEntryName.mdx +1 -1
- package/docs/en/configure/app/source/module-scopes.mdx +62 -2
- package/docs/en/configure/app/source/pre-entry.mdx +8 -2
- package/docs/en/configure/app/source/resolve-extension-prefix.mdx +48 -2
- package/docs/en/configure/app/source/resolve-main-fields.mdx +39 -2
- package/docs/en/configure/app/source/transform-import.mdx +56 -2
- package/docs/en/configure/app/tools/autoprefixer.mdx +41 -2
- package/docs/en/configure/app/tools/babel.mdx +218 -2
- package/docs/en/configure/app/tools/bundler-chain.mdx +23 -2
- package/docs/en/configure/app/tools/css-extract.mdx +31 -2
- package/docs/en/configure/app/tools/css-loader.mdx +14 -2
- package/docs/en/configure/app/tools/dev-server.mdx +435 -2
- package/docs/en/configure/app/tools/esbuild.mdx +1 -1
- package/docs/en/configure/app/tools/html-plugin.mdx +21 -2
- package/docs/en/configure/app/tools/less.mdx +78 -2
- package/docs/en/configure/app/tools/minify-css.mdx +50 -2
- package/docs/en/configure/app/tools/postcss.mdx +30 -2
- package/docs/en/configure/app/tools/pug.mdx +47 -2
- package/docs/en/configure/app/tools/rspack.mdx +8 -2
- package/docs/en/configure/app/tools/sass.mdx +75 -2
- package/docs/en/configure/app/tools/style-loader.mdx +8 -2
- package/docs/en/configure/app/tools/styled-components.mdx +48 -2
- package/docs/en/configure/app/tools/swc.mdx +33 -2
- package/docs/en/configure/app/tools/terser.mdx +49 -2
- package/docs/en/configure/app/tools/ts-checker.mdx +49 -2
- package/docs/en/configure/app/tools/ts-loader.mdx +63 -2
- package/docs/en/configure/app/tools/webpack-chain.mdx +239 -2
- package/docs/en/configure/app/tools/webpack.mdx +295 -2
- package/docs/en/guides/advanced-features/_meta.json +0 -1
- package/docs/en/guides/advanced-features/rspack-start.mdx +2 -2
- package/docs/en/guides/basic-features/css/css-modules.mdx +2 -2
- package/docs/en/guides/basic-features/output-files.mdx +1 -1
- package/docs/en/guides/basic-features/render/ssg.mdx +1 -1
- package/docs/en/guides/concept/builder.mdx +1 -1
- package/docs/en/guides/get-started/glossary.mdx +7 -7
- package/docs/en/guides/get-started/quick-start.mdx +1 -1
- package/docs/en/guides/topic-detail/_meta.json +0 -6
- package/docs/en/guides/topic-detail/micro-frontend/c01-introduction.mdx +1 -1
- package/docs/en/guides/topic-detail/model/quick-start.mdx +5 -0
- package/docs/en/guides/troubleshooting/builder.mdx +2 -2
- package/docs/en/plugin/cli-plugins/plugin-swc.mdx +4 -4
- package/docs/en/plugin/rsbuild-plugins/plugin-esbuild.mdx +4 -4
- package/docs/zh/apis/app/commands.mdx +0 -18
- package/docs/zh/community/contributing-guide.mdx +0 -1
- package/docs/zh/components/builder.mdx +3 -0
- package/docs/zh/components/bundler.mdx +4 -0
- package/docs/zh/components/enableSwc.mdx +17 -0
- package/docs/zh/components/esbuild.mdx +3 -0
- package/docs/zh/components/micro-frontend.mdx +6 -0
- package/docs/zh/components/module-federation.mdx +7 -0
- package/docs/zh/components/nodeVersion.mdx +28 -0
- package/docs/zh/components/output-asset-prefix-extend.mdx +0 -0
- package/docs/zh/components/output-polyfill-extend.mdx +1 -0
- package/docs/zh/components/prerequisites.mdx +1 -1
- package/docs/zh/components/rsbuild-config-tooltip.mdx +5 -0
- package/docs/zh/components/rsbuild.mdx +3 -0
- package/docs/zh/components/rspack.mdx +3 -0
- package/docs/zh/components/rspackPrecautions.mdx +6 -0
- package/docs/zh/components/rspackTip.mdx +7 -0
- package/docs/zh/components/swc.mdx +3 -0
- package/docs/zh/configure/app/dev/asset-prefix.mdx +12 -2
- package/docs/zh/configure/app/dev/before-start-url.mdx +14 -2
- package/docs/zh/configure/app/dev/client.mdx +20 -16
- package/docs/zh/configure/app/dev/hmr.mdx +8 -2
- package/docs/zh/configure/app/dev/host.mdx +15 -2
- package/docs/zh/configure/app/dev/https.mdx +72 -2
- package/docs/zh/configure/app/dev/live-reload.mdx +3 -15
- package/docs/zh/configure/app/dev/port.mdx +18 -2
- package/docs/zh/configure/app/dev/progress-bar.mdx +17 -2
- package/docs/zh/configure/app/dev/setup-middlewares.mdx +26 -39
- package/docs/zh/configure/app/dev/start-url.mdx +47 -2
- package/docs/zh/configure/app/dev/watch-files.mdx +5 -39
- package/docs/zh/configure/app/dev/write-to-disk.mdx +3 -26
- package/docs/zh/configure/app/experiments/lazy-compilation.mdx +84 -2
- package/docs/zh/configure/app/experiments/source-build.mdx +29 -2
- package/docs/zh/configure/app/html/app-icon.mdx +48 -2
- package/docs/zh/configure/app/html/crossorigin.mdx +9 -2
- package/docs/zh/configure/app/html/disable-html-folder.mdx +34 -2
- package/docs/zh/configure/app/html/favicon-by-entries.mdx +30 -2
- package/docs/zh/configure/app/html/favicon.mdx +15 -2
- package/docs/zh/configure/app/html/inject-by-entries.mdx +30 -2
- package/docs/zh/configure/app/html/inject.mdx +8 -2
- package/docs/zh/configure/app/html/meta-by-entries.mdx +41 -2
- package/docs/zh/configure/app/html/meta.mdx +22 -2
- package/docs/zh/configure/app/html/mount-id.mdx +8 -2
- package/docs/zh/configure/app/html/script-loading.mdx +8 -2
- package/docs/zh/configure/app/html/tags-by-entries.mdx +37 -2
- package/docs/zh/configure/app/html/tags.mdx +13 -2
- package/docs/zh/configure/app/html/template-by-entries.mdx +26 -2
- package/docs/zh/configure/app/html/template-parameters-by-entries.mdx +29 -2
- package/docs/zh/configure/app/html/template-parameters.mdx +31 -2
- package/docs/zh/configure/app/html/template.mdx +8 -2
- package/docs/zh/configure/app/html/title-by-entries.mdx +30 -2
- package/docs/zh/configure/app/html/title.mdx +16 -2
- package/docs/zh/configure/app/output/asset-prefix.mdx +12 -2
- package/docs/zh/configure/app/output/assets-retry.mdx +72 -2
- package/docs/zh/configure/app/output/charset.mdx +8 -2
- package/docs/zh/configure/app/output/clean-dist-path.mdx +13 -2
- package/docs/zh/configure/app/output/convert-to-rem.mdx +77 -2
- package/docs/zh/configure/app/output/copy.mdx +6 -2
- package/docs/zh/configure/app/output/css-module-local-ident-name.mdx +14 -2
- package/docs/zh/configure/app/output/css-modules.mdx +46 -2
- package/docs/zh/configure/app/output/data-uri-limit.mdx +24 -2
- package/docs/zh/configure/app/output/disable-css-extract.mdx +9 -2
- package/docs/zh/configure/app/output/disable-css-module-extension.mdx +52 -2
- package/docs/zh/configure/app/output/disable-filename-hash.mdx +9 -2
- package/docs/zh/configure/app/output/disable-inline-runtime-chunk.mdx +38 -2
- package/docs/zh/configure/app/output/disable-minimize.mdx +7 -2
- package/docs/zh/configure/app/output/disable-source-map.mdx +24 -2
- package/docs/zh/configure/app/output/disable-svgr.mdx +14 -2
- package/docs/zh/configure/app/output/disable-ts-checker.mdx +46 -2
- package/docs/zh/configure/app/output/dist-path.mdx +39 -2
- package/docs/zh/configure/app/output/enable-asset-fallback.mdx +29 -2
- package/docs/zh/configure/app/output/enable-asset-manifest.mdx +33 -2
- package/docs/zh/configure/app/output/enable-css-module-tsdeclaration.mdx +25 -2
- package/docs/zh/configure/app/output/enable-inline-scripts.mdx +15 -2
- package/docs/zh/configure/app/output/enable-inline-styles.mdx +15 -2
- package/docs/zh/configure/app/output/enable-latest-decorators.mdx +7 -2
- package/docs/zh/configure/app/output/externals.mdx +18 -2
- package/docs/zh/configure/app/output/filename-hash.mdx +4 -27
- package/docs/zh/configure/app/output/filename.mdx +47 -2
- package/docs/zh/configure/app/output/inject-styles.mdx +15 -0
- package/docs/zh/configure/app/output/inline-scripts.mdx +34 -0
- package/docs/zh/configure/app/output/inline-styles.mdx +34 -0
- package/docs/zh/configure/app/output/legal-comments.mdx +16 -2
- package/docs/zh/configure/app/output/minify.mdx +27 -0
- package/docs/zh/configure/app/output/override-browserslist.mdx +20 -2
- package/docs/zh/configure/app/output/polyfill.mdx +12 -2
- package/docs/zh/configure/app/output/source-map.mdx +30 -0
- package/docs/zh/configure/app/output/ssg.mdx +19 -15
- package/docs/zh/configure/app/output/svg-default-export.mdx +27 -2
- package/docs/zh/configure/app/performance/build-cache.mdx +77 -2
- package/docs/zh/configure/app/performance/bundle-analyze.mdx +18 -2
- package/docs/zh/configure/app/performance/chunk-split.mdx +38 -2
- package/docs/zh/configure/app/performance/dns-prefetch.mdx +13 -2
- package/docs/zh/configure/app/performance/preconnect.mdx +14 -2
- package/docs/zh/configure/app/performance/prefetch.mdx +19 -2
- package/docs/zh/configure/app/performance/preload.mdx +21 -2
- package/docs/zh/configure/app/performance/print-file-size.mdx +38 -2
- package/docs/zh/configure/app/performance/profile.mdx +8 -2
- package/docs/zh/configure/app/performance/remove-console.mdx +8 -2
- package/docs/zh/configure/app/performance/remove-moment-locale.mdx +8 -2
- package/docs/zh/configure/app/performance/transform-lodash.mdx +42 -2
- package/docs/zh/configure/app/plugins.mdx +1 -1
- package/docs/zh/configure/app/security/check-syntax.mdx +66 -2
- package/docs/zh/configure/app/security/nonce.mdx +13 -2
- package/docs/zh/configure/app/security/sri.mdx +19 -2
- package/docs/zh/configure/app/server/port.mdx +5 -0
- package/docs/zh/configure/app/server/ssr.mdx +10 -9
- package/docs/zh/configure/app/source/alias-strategy.mdx +8 -2
- package/docs/zh/configure/app/source/alias.mdx +17 -2
- package/docs/zh/configure/app/source/config-dir.mdx +1 -1
- package/docs/zh/configure/app/source/decorators.mdx +8 -20
- package/docs/zh/configure/app/source/define.mdx +14 -2
- package/docs/zh/configure/app/source/enable-async-entry.mdx +1 -1
- package/docs/zh/configure/app/source/entries-dir.mdx +1 -1
- package/docs/zh/configure/app/source/exclude.mdx +8 -2
- package/docs/zh/configure/app/source/global-vars.mdx +102 -2
- package/docs/zh/configure/app/source/include.mdx +19 -2
- package/docs/zh/configure/app/source/mainEntryName.mdx +1 -1
- package/docs/zh/configure/app/source/module-scopes.mdx +62 -2
- package/docs/zh/configure/app/source/pre-entry.mdx +8 -2
- package/docs/zh/configure/app/source/resolve-extension-prefix.mdx +50 -2
- package/docs/zh/configure/app/source/resolve-main-fields.mdx +39 -2
- package/docs/zh/configure/app/source/transform-import.mdx +56 -2
- package/docs/zh/configure/app/tools/autoprefixer.mdx +41 -2
- package/docs/zh/configure/app/tools/babel.mdx +218 -2
- package/docs/zh/configure/app/tools/bundler-chain.mdx +26 -2
- package/docs/zh/configure/app/tools/css-extract.mdx +28 -2
- package/docs/zh/configure/app/tools/css-loader.mdx +15 -2
- package/docs/zh/configure/app/tools/dev-server.mdx +435 -2
- package/docs/zh/configure/app/tools/esbuild.mdx +1 -1
- package/docs/zh/configure/app/tools/html-plugin.mdx +21 -2
- package/docs/zh/configure/app/tools/less.mdx +79 -2
- package/docs/zh/configure/app/tools/minify-css.mdx +50 -2
- package/docs/zh/configure/app/tools/postcss.mdx +31 -2
- package/docs/zh/configure/app/tools/pug.mdx +47 -2
- package/docs/zh/configure/app/tools/rspack.mdx +8 -2
- package/docs/zh/configure/app/tools/sass.mdx +73 -2
- package/docs/zh/configure/app/tools/style-loader.mdx +8 -2
- package/docs/zh/configure/app/tools/styled-components.mdx +47 -2
- package/docs/zh/configure/app/tools/swc.mdx +33 -2
- package/docs/zh/configure/app/tools/terser.mdx +49 -2
- package/docs/zh/configure/app/tools/ts-checker.mdx +49 -2
- package/docs/zh/configure/app/tools/ts-loader.mdx +63 -2
- package/docs/zh/configure/app/tools/webpack-chain.mdx +243 -2
- package/docs/zh/configure/app/tools/webpack.mdx +295 -2
- package/docs/zh/guides/advanced-features/_meta.json +0 -1
- package/docs/zh/guides/advanced-features/rspack-start.mdx +2 -2
- package/docs/zh/guides/basic-features/css/css-modules.mdx +1 -1
- package/docs/zh/guides/basic-features/output-files.mdx +2 -2
- package/docs/zh/guides/concept/builder.mdx +1 -1
- package/docs/zh/guides/get-started/glossary.mdx +7 -7
- package/docs/zh/guides/get-started/quick-start.mdx +1 -1
- package/docs/zh/guides/topic-detail/_meta.json +0 -6
- package/docs/zh/guides/topic-detail/micro-frontend/c01-introduction.mdx +1 -1
- package/docs/zh/guides/topic-detail/model/quick-start.mdx +5 -0
- package/docs/zh/guides/troubleshooting/builder.mdx +2 -2
- package/docs/zh/plugin/cli-plugins/plugin-swc.mdx +4 -4
- package/docs/zh/plugin/rsbuild-plugins/plugin-esbuild.mdx +6 -6
- package/package.json +6 -11
- package/src/components/RsbuildLink/index.tsx +19 -0
- /package/docs/en/configure/app/output/{splitRouteChunks.mdx → split-route-chunks.mdx} +0 -0
- /package/docs/zh/configure/app/output/{splitRouteChunks.mdx → split-route-chunks.mdx} +0 -0
@@ -1,9 +1,15 @@
|
|
1
1
|
---
|
2
2
|
title: rspack
|
3
|
+
configName: tools.rspack
|
3
4
|
---
|
4
5
|
|
5
6
|
# tools.rspack
|
6
7
|
|
7
|
-
|
8
|
+
- **类型:** `Rspack.Configuration | Function | undefined`
|
9
|
+
- **默认值:** `undefined`
|
8
10
|
|
9
|
-
|
11
|
+
`tools.rspack` 选项用于修改 [Rspack](https://rspack.dev/) 的配置项。
|
12
|
+
|
13
|
+
import RsbuildConig from '@site-docs/components/rsbuild-config-tooltip';
|
14
|
+
|
15
|
+
<RsbuildConig />
|
@@ -4,6 +4,77 @@ title: sass
|
|
4
4
|
|
5
5
|
# tools.sass
|
6
6
|
|
7
|
-
|
7
|
+
- **类型:** `Object | Function`
|
8
|
+
- **默认值:**
|
8
9
|
|
9
|
-
|
10
|
+
```js
|
11
|
+
const defaultOptions = {
|
12
|
+
// 默认在开发环境下启用 CSS 的 Source Map
|
13
|
+
sourceMap: isDev,
|
14
|
+
};
|
15
|
+
```
|
16
|
+
|
17
|
+
你可以通过 `tools.sass` 修改 [sass-loader](https://github.com/webpack-contrib/sass-loader) 的配置。
|
18
|
+
|
19
|
+
### Object 类型
|
20
|
+
|
21
|
+
当 `tools.sass` 的值为 `Object` 类型时,会与默认配置通过 Object.assign 进行浅层合并,值得注意的是,`sassOptions` 会通过 deepMerge 进行深层合并。
|
22
|
+
|
23
|
+
```js
|
24
|
+
export default {
|
25
|
+
tools: {
|
26
|
+
sass: {
|
27
|
+
sourceMap: true,
|
28
|
+
},
|
29
|
+
},
|
30
|
+
};
|
31
|
+
```
|
32
|
+
|
33
|
+
### Function 类型
|
34
|
+
|
35
|
+
当 `tools.sass` 为 Function 类型时,默认配置作为第一个参数传入,可以直接修改配置对象,也可以返回一个值作为最终结果,第二个参数提供了一些可以直接调用的工具函数:
|
36
|
+
|
37
|
+
```js
|
38
|
+
export default {
|
39
|
+
tools: {
|
40
|
+
sass(config) {
|
41
|
+
// 修改 sourceMap 配置
|
42
|
+
config.additionalData = async (content, loaderContext) => {
|
43
|
+
// ...
|
44
|
+
};
|
45
|
+
},
|
46
|
+
},
|
47
|
+
};
|
48
|
+
```
|
49
|
+
|
50
|
+
### 修改 Sass 版本
|
51
|
+
|
52
|
+
在某些场景下,如果你需要使用特定的 Sass 版本,而不是使用 Modern.js 内置的 Dart Sass v1,可以在项目中安装需要使用的 Sass 版本,并通过 `sass-loader` 的 `implementation` 选项设置。
|
53
|
+
|
54
|
+
```js
|
55
|
+
export default {
|
56
|
+
tools: {
|
57
|
+
sass: {
|
58
|
+
implementation: require('sass'),
|
59
|
+
},
|
60
|
+
},
|
61
|
+
};
|
62
|
+
```
|
63
|
+
|
64
|
+
### 工具函数
|
65
|
+
|
66
|
+
#### addExcludes
|
67
|
+
|
68
|
+
- **类型:** `(excludes: RegExp | RegExp[]) => void`
|
69
|
+
|
70
|
+
用来指定 `sass-loader` 不编译哪些文件,你可以传入一个或多个正则表达式来匹配 sass 文件的路径。例如:
|
71
|
+
|
72
|
+
```js
|
73
|
+
export default {
|
74
|
+
tools: {
|
75
|
+
sass(config, { addExcludes }) {
|
76
|
+
addExcludes(/node_modules/);
|
77
|
+
},
|
78
|
+
},
|
79
|
+
};
|
80
|
+
```
|
@@ -1,9 +1,15 @@
|
|
1
1
|
---
|
2
2
|
title: styleLoader
|
3
|
+
configName: tools.styleLoader
|
3
4
|
---
|
4
5
|
|
5
6
|
# tools.styleLoader
|
6
7
|
|
7
|
-
|
8
|
+
- **类型:** `Object | Function`
|
9
|
+
- **默认值:** `{}`
|
8
10
|
|
9
|
-
|
11
|
+
通过 `tools.styleLoader` 可以设置 [style-loader](https://github.com/webpack-contrib/style-loader) 的配置项。
|
12
|
+
|
13
|
+
import RsbuildConig from '@site-docs/components/rsbuild-config-tooltip';
|
14
|
+
|
15
|
+
<RsbuildConig />
|
@@ -4,6 +4,51 @@ title: styledComponents
|
|
4
4
|
|
5
5
|
# tools.styledComponents
|
6
6
|
|
7
|
-
|
7
|
+
- **类型:** `Object | Function | false`
|
8
|
+
- **默认值:**
|
8
9
|
|
9
|
-
|
10
|
+
```js
|
11
|
+
{
|
12
|
+
displayName: true,
|
13
|
+
// 在 SSR 构建中 isSSR 为 true
|
14
|
+
ssr: isSSR,
|
15
|
+
// 在生产环境构建时启用 `pure` 来优化包体积
|
16
|
+
pure: isProd,
|
17
|
+
transpileTemplateLiterals: true,
|
18
|
+
}
|
19
|
+
```
|
20
|
+
|
21
|
+
对应 [babel-plugin-styled-components](https://github.com/styled-components/babel-plugin-styled-components) 或使用 SWC 时 [@swc/plugin-styled-components](https://github.com/swc-project/plugins/tree/main/packages/styled-components) 的配置。 值为 `Object` 类型时,利用 Object.assign 函数与默认配置合并。比如:
|
22
|
+
|
23
|
+
```js
|
24
|
+
export default {
|
25
|
+
tools: {
|
26
|
+
styledComponents: {
|
27
|
+
pure: false,
|
28
|
+
},
|
29
|
+
},
|
30
|
+
};
|
31
|
+
```
|
32
|
+
|
33
|
+
值为 `Function` 类型时,第一个参数为默认配置,第二个参数提供了一些可以直接调用的工具函数:
|
34
|
+
|
35
|
+
```js
|
36
|
+
export default {
|
37
|
+
tools: {
|
38
|
+
styledComponents(config) {
|
39
|
+
// 修改 pure 配置
|
40
|
+
config.pure = false;
|
41
|
+
},
|
42
|
+
},
|
43
|
+
};
|
44
|
+
```
|
45
|
+
|
46
|
+
该特性默认启用,你可以配置 `tools.styledComponents` 为 `false` 来关闭该行为,关闭后可以提升编译性能:
|
47
|
+
|
48
|
+
```js
|
49
|
+
export default {
|
50
|
+
tools: {
|
51
|
+
styledComponents: false,
|
52
|
+
},
|
53
|
+
};
|
54
|
+
```
|
@@ -9,7 +9,7 @@ title: swc
|
|
9
9
|
|
10
10
|
## 介绍
|
11
11
|
|
12
|
-
import SWC from '@
|
12
|
+
import SWC from '@site-docs/components/swc.mdx';
|
13
13
|
|
14
14
|
<SWC />
|
15
15
|
|
@@ -37,9 +37,40 @@ export default defineConfig<'rspack'>({
|
|
37
37
|
|
38
38
|
更多用法可参考 [Rsbuild - tools.swc](https://rsbuild.dev/zh/config/tools/swc)。
|
39
39
|
|
40
|
+
### 注册 SWC 插件
|
41
|
+
|
42
|
+
Modern.js 支持通过 `tools.swc` 注册 SWC 的 Wasm 插件,比如注册 [@swc/plugin-styled-components](https://www.npmjs.com/package/@swc/plugin-styled-components):
|
43
|
+
|
44
|
+
```ts
|
45
|
+
export default {
|
46
|
+
tools: {
|
47
|
+
swc: {
|
48
|
+
jsc: {
|
49
|
+
experimental: {
|
50
|
+
plugins: [['@swc/plugin-styled-components', {}]],
|
51
|
+
},
|
52
|
+
},
|
53
|
+
},
|
54
|
+
},
|
55
|
+
};
|
56
|
+
```
|
57
|
+
|
58
|
+
需要注意的是,SWC 的插件仍然是一个实验性功能,目前 SWC 的 Wasm 插件是不向后兼容的,SWC 插件的版本与 Rspack 依赖的 swc_core 版本存在强耦合关系。
|
59
|
+
|
60
|
+
这意味着,你需要选择和当前 swc_core 版本匹配的 SWC 插件,才能使它正常执行。如果你使用的 SWC 插件版本与 Rspack 依赖的 swc_core 版本不匹配,Rspack 在执行构建时会抛出如下错误:
|
61
|
+
|
62
|
+
```
|
63
|
+
1: failed to run Wasm plugin transform. Please ensure the version of `swc_core`
|
64
|
+
used by the plugin is compatible with the host runtime.
|
65
|
+
```
|
66
|
+
|
67
|
+
如果你遇到了以上问题,通常可行的解决方法是将 Modern.js 和 SWC 插件都升级到最新版本。
|
68
|
+
|
69
|
+
详情可参考 [Rsbuild - SWC 插件版本](https://rsbuild.dev/zh/guide/basic/configure-swc#swc-%E6%8F%92%E4%BB%B6%E7%89%88%E6%9C%AC)。
|
70
|
+
|
40
71
|
## 在 Webpack 模式下使用
|
41
72
|
|
42
|
-
import EnableSWC from '@
|
73
|
+
import EnableSWC from '@site-docs/components/enableSwc.mdx';
|
43
74
|
|
44
75
|
<EnableSWC />
|
45
76
|
|
@@ -4,6 +4,53 @@ title: terser
|
|
4
4
|
|
5
5
|
# tools.terser
|
6
6
|
|
7
|
-
|
7
|
+
- **类型:** `Object | Function | undefined`
|
8
|
+
- **默认值:**
|
8
9
|
|
9
|
-
|
10
|
+
```js
|
11
|
+
const defaultTerserOptions = {
|
12
|
+
terserOptions: {
|
13
|
+
mangle: {
|
14
|
+
safari10: true,
|
15
|
+
},
|
16
|
+
},
|
17
|
+
};
|
18
|
+
```
|
19
|
+
|
20
|
+
- **打包工具:** `仅支持 webpack`
|
21
|
+
|
22
|
+
在生产环境构建时,Modern.js 会通过 [terser-webpack-plugin](https://github.com/webpack-contrib/terser-webpack-plugin) 对 JavaScript 代码进行压缩优化。可以通过 `tools.terser` 修改 [terser-webpack-plugin](https://github.com/webpack-contrib/terser-webpack-plugin) 的配置。
|
23
|
+
|
24
|
+
### Object 类型
|
25
|
+
|
26
|
+
当 `tools.terser` 的值为 `Object` 类型时,会与默认配置通过 `Object.assign` 合并。
|
27
|
+
|
28
|
+
例如通过 `exclude` 排除部分文件的压缩:
|
29
|
+
|
30
|
+
```js
|
31
|
+
export default {
|
32
|
+
tools: {
|
33
|
+
terser: {
|
34
|
+
exclude: /\/excludes/,
|
35
|
+
},
|
36
|
+
},
|
37
|
+
};
|
38
|
+
```
|
39
|
+
|
40
|
+
### Function 类型
|
41
|
+
|
42
|
+
当 `tools.terser` 配置为 `Function` 类型时,默认配置作为第一个参数传入,可以直接修改配置对象,也可以返回一个值作为最终结果。
|
43
|
+
|
44
|
+
```js
|
45
|
+
export default {
|
46
|
+
tools: {
|
47
|
+
terser: opts => {
|
48
|
+
opts.exclude = /\/excludes/;
|
49
|
+
},
|
50
|
+
},
|
51
|
+
};
|
52
|
+
```
|
53
|
+
|
54
|
+
:::tip 禁用代码压缩
|
55
|
+
如果你需要禁用代码压缩,可以使用 [output.disableMinimize](https://modernjs.dev/builder/api/config-output.html#outputdisableminimize) 配置项。
|
56
|
+
:::
|
@@ -4,6 +4,53 @@ title: tsChecker
|
|
4
4
|
|
5
5
|
# tools.tsChecker
|
6
6
|
|
7
|
-
|
7
|
+
- **类型:** `Object | Function`
|
8
|
+
- **默认值:**
|
8
9
|
|
9
|
-
|
10
|
+
```js
|
11
|
+
const defaultOptions = {
|
12
|
+
typescript: {
|
13
|
+
// avoid OOM issue
|
14
|
+
memoryLimit: 8192,
|
15
|
+
// use tsconfig of user project
|
16
|
+
configFile: tsconfigPath,
|
17
|
+
// use typescript of user project
|
18
|
+
typescriptPath: require.resolve('typescript'),
|
19
|
+
},
|
20
|
+
issue: {
|
21
|
+
exclude: [
|
22
|
+
{ file: '**/*.(spec|test).ts' },
|
23
|
+
{ file: '**/node_modules/**/*' },
|
24
|
+
],
|
25
|
+
},
|
26
|
+
logger: {
|
27
|
+
log() {
|
28
|
+
// do nothing
|
29
|
+
// we only want to display error messages
|
30
|
+
},
|
31
|
+
error(message: string) {
|
32
|
+
console.error(message.replace(/ERROR/g, 'Type Error'));
|
33
|
+
},
|
34
|
+
},
|
35
|
+
},
|
36
|
+
```
|
37
|
+
|
38
|
+
默认情况下,Modern.js 会开启 [@rsbuild/plugin-type-check](https://rsbuild.dev/zh/plugins/list/plugin-type-check) 进行类型检查。你可以通过 `output.disableTsChecker` 配置项来关闭类型检查。
|
39
|
+
|
40
|
+
## 示例
|
41
|
+
|
42
|
+
当 `tsChecker` 的值为 Object 类型时,会与默认配置进行深层合并。
|
43
|
+
|
44
|
+
```ts
|
45
|
+
export default {
|
46
|
+
tools: {
|
47
|
+
tsChecker: {
|
48
|
+
issue: {
|
49
|
+
exclude: [({ file = '' }) => /[\\/]some-folder[\\/]/.test(file)],
|
50
|
+
},
|
51
|
+
},
|
52
|
+
},
|
53
|
+
};
|
54
|
+
```
|
55
|
+
|
56
|
+
> 请参考 [@rsbuild/plugin-type-check](https://rsbuild.dev/zh/plugins/list/plugin-type-check) 了解更多用法。
|
@@ -4,6 +4,67 @@ title: tsLoader
|
|
4
4
|
|
5
5
|
# tools.tsLoader
|
6
6
|
|
7
|
-
|
7
|
+
- **类型:** `Object | Function | undefined`
|
8
|
+
- **默认值:** `undefined`
|
9
|
+
- **打包工具:** `仅支持 webpack`
|
8
10
|
|
9
|
-
|
11
|
+
:::warning 不再推荐使用 ts-loader
|
12
|
+
使用 [babel-loader](https://modernjs.dev/builder/guide/basic/typescript.html#%E4%B8%BA%E4%BB%80%E4%B9%88%E9%BB%98%E8%AE%A4%E4%BD%BF%E7%94%A8-babel) 或 [Rspack](https://modernjs.dev/guide/advanced/rspack-start.html) 转译 TypeScript 代码的性能明显优于 ts-loader 且能够使用更多拓展能力。
|
13
|
+
|
14
|
+
启用 ts-loader 时将无法使用 [source.transformImport](https://modernjs.dev/configure/app/source/transform-import.html) 和 [tools.styledComponents](https://modernjs.dev/configure/app/tools/styled-components.html) 等由 Babel 和 SWC 提供支持的能力。
|
15
|
+
:::
|
16
|
+
|
17
|
+
项目中默认不开启 ts-loader,当 `tools.tsLoader` 不为 undefined 则表示开启 ts-loader,同时禁用 babel-loader 对 TypeScript 的编译。
|
18
|
+
|
19
|
+
### Object 类型
|
20
|
+
|
21
|
+
当此值为 Object 类型时,与默认配置通过 Object.assign 合并。
|
22
|
+
|
23
|
+
默认配置如下:
|
24
|
+
|
25
|
+
```json
|
26
|
+
{
|
27
|
+
"compilerOptions": {
|
28
|
+
"target": "es5",
|
29
|
+
"module": "ESNext"
|
30
|
+
},
|
31
|
+
"transpileOnly": true,
|
32
|
+
"allowTsInNodeModules": true
|
33
|
+
}
|
34
|
+
```
|
35
|
+
|
36
|
+
你可以通过 `tools.tsLoader` 配置项来覆盖默认配置:
|
37
|
+
|
38
|
+
```ts
|
39
|
+
export default {
|
40
|
+
tools: {
|
41
|
+
tsLoader: {
|
42
|
+
allowTsInNodeModules: false,
|
43
|
+
},
|
44
|
+
},
|
45
|
+
};
|
46
|
+
```
|
47
|
+
|
48
|
+
### Function 类型
|
49
|
+
|
50
|
+
当此值为 Function 类型时,默认配置作为第一参数传入,可以直接修改配置对象,也可以返回一个对象作为最终配置;第二个参数为修改 `ts-loader` 配置工具函数集合:
|
51
|
+
|
52
|
+
```ts
|
53
|
+
export default {
|
54
|
+
tools: {
|
55
|
+
tsLoader: opts => {
|
56
|
+
opts.allowTsInNodeModules = false;
|
57
|
+
},
|
58
|
+
},
|
59
|
+
};
|
60
|
+
```
|
61
|
+
|
62
|
+
### 工具函数
|
63
|
+
|
64
|
+
#### addIncludes
|
65
|
+
|
66
|
+
已废弃,请使用 [source.include](https://modernjs.dev/configure/app/source/include.html) 代替,两者功能完全一致。
|
67
|
+
|
68
|
+
#### addExcludes
|
69
|
+
|
70
|
+
已废弃,请使用 [source.exclude](https://modernjs.dev/configure/app/source/exclude.html) 代替,两者功能完全一致。
|
@@ -4,6 +4,247 @@ title: webpackChain
|
|
4
4
|
|
5
5
|
# tools.webpackChain
|
6
6
|
|
7
|
-
|
7
|
+
- **类型:** `Function | undefined`
|
8
|
+
- **默认值:** `undefined`
|
9
|
+
- **打包工具:** `仅支持 webpack`
|
8
10
|
|
9
|
-
|
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)。
|