@modern-js/main-doc 2.0.0-beta.1 → 2.0.0-beta.3
Sign up to get free protection for your applications and to get access to all the features.
- package/.turbo/turbo-build.log +1 -1
- package/en/docusaurus-plugin-content-docs/current/apis/app/commands/build.md +1 -1
- package/en/docusaurus-plugin-content-docs/current/apis/app/commands/dev.md +1 -1
- package/en/docusaurus-plugin-content-docs/current/apis/app/commands/lint.md +1 -1
- package/en/docusaurus-plugin-content-docs/current/apis/app/commands/new.md +1 -4
- package/en/docusaurus-plugin-content-docs/current/apis/app/commands/start.md +1 -1
- package/en/docusaurus-plugin-content-docs/current/apis/app/commands/test.md +1 -1
- package/en/docusaurus-plugin-content-docs/current/apis/app/overview.md +1 -1
- package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/core/bootstrap.md +17 -3
- package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/model/auto-actions.md +1 -1
- package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/model/connect.md +1 -1
- package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/model/create-app.md +2 -2
- package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/model/create-store.md +1 -1
- package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/model/handle-effect.md +1 -1
- package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/model/model_.md +1 -1
- package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/model/use-local-model.md +1 -1
- package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/model/use-model.md +1 -1
- package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/model/use-static-model.md +1 -1
- package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/model/use-store.md +1 -23
- package/en/docusaurus-plugin-content-docs/current/components/command-tip.md +56 -0
- package/en/docusaurus-plugin-content-docs/current/components/reduck-migration.md +1 -0
- package/en/docusaurus-plugin-content-docs/current/components/reduck-tip.md +5 -0
- package/en/docusaurus-plugin-content-docs/current/configure/app/dev/asset-prefix.md +1 -1
- package/en/docusaurus-plugin-content-docs/current/configure/app/dev/hmr.md +1 -1
- package/en/docusaurus-plugin-content-docs/current/configure/app/dev/https.md +1 -1
- package/en/docusaurus-plugin-content-docs/current/configure/app/dev/port.md +1 -1
- package/en/docusaurus-plugin-content-docs/current/configure/app/dev/progress-bar.md +1 -1
- package/en/docusaurus-plugin-content-docs/current/configure/app/dev/start-url.md +1 -1
- package/en/docusaurus-plugin-content-docs/current/configure/app/experiments/lazy-compilation.md +1 -1
- package/en/docusaurus-plugin-content-docs/current/configure/app/html/app-icon.md +1 -1
- package/en/docusaurus-plugin-content-docs/current/configure/app/html/crossorigin.md +1 -1
- package/en/docusaurus-plugin-content-docs/current/configure/app/html/disable-html-folder.md +1 -1
- package/en/docusaurus-plugin-content-docs/current/configure/app/html/favicon-by-entries.md +1 -1
- package/en/docusaurus-plugin-content-docs/current/configure/app/html/favicon.md +1 -1
- package/en/docusaurus-plugin-content-docs/current/configure/app/html/inject-by-entries.md +1 -1
- package/en/docusaurus-plugin-content-docs/current/configure/app/html/inject.md +1 -1
- package/en/docusaurus-plugin-content-docs/current/configure/app/html/meta-by-entries.md +1 -1
- package/en/docusaurus-plugin-content-docs/current/configure/app/html/meta.md +1 -1
- package/en/docusaurus-plugin-content-docs/current/configure/app/html/mount-id.md +1 -1
- package/en/docusaurus-plugin-content-docs/current/configure/app/html/template-by-entries.md +1 -1
- package/en/docusaurus-plugin-content-docs/current/configure/app/html/template-parameters-by-entries.md +1 -1
- package/en/docusaurus-plugin-content-docs/current/configure/app/html/template-parameters.md +1 -1
- package/en/docusaurus-plugin-content-docs/current/configure/app/html/template.md +1 -1
- package/en/docusaurus-plugin-content-docs/current/configure/app/html/title-by-entries.md +1 -1
- package/en/docusaurus-plugin-content-docs/current/configure/app/html/title.md +1 -1
- package/en/docusaurus-plugin-content-docs/current/configure/app/output/asset-prefix.md +1 -1
- package/en/docusaurus-plugin-content-docs/current/configure/app/output/assets-retry.md +1 -1
- package/en/docusaurus-plugin-content-docs/current/configure/app/output/charset.md +1 -1
- package/en/docusaurus-plugin-content-docs/current/configure/app/output/clean-dist-path.md +1 -1
- package/en/docusaurus-plugin-content-docs/current/configure/app/output/convert-to-rem.md +1 -1
- package/en/docusaurus-plugin-content-docs/current/configure/app/output/copy.md +1 -1
- package/en/docusaurus-plugin-content-docs/current/configure/app/output/css-module-local-ident-name.md +1 -1
- package/en/docusaurus-plugin-content-docs/current/configure/app/output/data-uri-limit.md +1 -1
- package/en/docusaurus-plugin-content-docs/current/configure/app/output/disable-css-extract.md +12 -0
- package/en/docusaurus-plugin-content-docs/current/configure/app/output/disable-css-module-extension.md +1 -1
- package/en/docusaurus-plugin-content-docs/current/configure/app/output/disable-filename-hash.md +1 -1
- package/en/docusaurus-plugin-content-docs/current/configure/app/output/disable-inline-runtime-chunk.md +1 -1
- package/en/docusaurus-plugin-content-docs/current/configure/app/output/disable-minimize.md +1 -1
- package/en/docusaurus-plugin-content-docs/current/configure/app/output/disable-source-map.md +1 -1
- package/en/docusaurus-plugin-content-docs/current/configure/app/output/disable-ts-checker.md +1 -1
- package/en/docusaurus-plugin-content-docs/current/configure/app/output/dist-path.md +1 -1
- package/en/docusaurus-plugin-content-docs/current/configure/app/output/enable-asset-fallback.md +1 -1
- package/en/docusaurus-plugin-content-docs/current/configure/app/output/enable-asset-manifest.md +1 -1
- package/en/docusaurus-plugin-content-docs/current/configure/app/output/enable-css-module-tsdeclaration.md +1 -1
- package/en/docusaurus-plugin-content-docs/current/configure/app/output/enable-inline-scripts.md +1 -1
- package/en/docusaurus-plugin-content-docs/current/configure/app/output/enable-inline-styles.md +1 -1
- package/en/docusaurus-plugin-content-docs/current/configure/app/output/enable-latest-decorators.md +1 -1
- package/en/docusaurus-plugin-content-docs/current/configure/app/output/externals.md +1 -1
- package/en/docusaurus-plugin-content-docs/current/configure/app/output/filename.md +1 -1
- package/en/docusaurus-plugin-content-docs/current/configure/app/output/legal-comments.md +1 -1
- package/en/docusaurus-plugin-content-docs/current/configure/app/output/override-browserslist.md +1 -1
- package/en/docusaurus-plugin-content-docs/current/configure/app/output/polyfill.md +1 -1
- package/en/docusaurus-plugin-content-docs/current/configure/app/output/svg-default-export.md +1 -1
- package/en/docusaurus-plugin-content-docs/current/configure/app/performance/build-cache.md +1 -1
- package/en/docusaurus-plugin-content-docs/current/configure/app/performance/bundle-analyze.md +1 -1
- package/en/docusaurus-plugin-content-docs/current/configure/app/performance/chunk-split.md +1 -1
- package/en/docusaurus-plugin-content-docs/current/configure/app/performance/print-file-size.md +1 -1
- package/en/docusaurus-plugin-content-docs/current/configure/app/performance/profile.md +1 -1
- package/en/docusaurus-plugin-content-docs/current/configure/app/performance/remove-console.md +1 -1
- package/en/docusaurus-plugin-content-docs/current/configure/app/performance/remove-moment-locale.md +1 -1
- package/en/docusaurus-plugin-content-docs/current/configure/app/plugins.md +1 -1
- package/en/docusaurus-plugin-content-docs/current/configure/app/runtime/router.md +1 -1
- package/en/docusaurus-plugin-content-docs/current/configure/app/security/sri.md +1 -1
- package/en/docusaurus-plugin-content-docs/current/configure/app/source/alias.md +1 -1
- package/en/docusaurus-plugin-content-docs/current/configure/app/source/compile-js-data-uri.md +1 -1
- package/en/docusaurus-plugin-content-docs/current/configure/app/source/define.md +1 -1
- package/en/docusaurus-plugin-content-docs/current/configure/app/source/exclude.md +1 -1
- package/en/docusaurus-plugin-content-docs/current/configure/app/source/global-vars.md +1 -1
- package/en/docusaurus-plugin-content-docs/current/configure/app/source/include.md +1 -1
- package/en/docusaurus-plugin-content-docs/current/configure/app/source/module-scopes.md +1 -1
- package/en/docusaurus-plugin-content-docs/current/configure/app/source/pre-entry.md +1 -1
- package/en/docusaurus-plugin-content-docs/current/configure/app/source/resolve-extension-prefix.md +1 -1
- package/en/docusaurus-plugin-content-docs/current/configure/app/source/resolve-main-fields.md +1 -1
- package/en/docusaurus-plugin-content-docs/current/configure/app/tools/autoprefixer.md +1 -1
- package/en/docusaurus-plugin-content-docs/current/configure/app/tools/babel.md +1 -1
- package/en/docusaurus-plugin-content-docs/current/configure/app/tools/css-extract.md +1 -1
- package/en/docusaurus-plugin-content-docs/current/configure/app/tools/css-loader.md +1 -1
- package/en/docusaurus-plugin-content-docs/current/configure/app/tools/dev-server.md +1 -1
- package/en/docusaurus-plugin-content-docs/current/configure/app/tools/html-plugin.md +1 -1
- package/en/docusaurus-plugin-content-docs/current/configure/app/tools/inspector.md +1 -1
- package/en/docusaurus-plugin-content-docs/current/configure/app/tools/less.md +1 -1
- package/en/docusaurus-plugin-content-docs/current/configure/app/tools/minify-css.md +1 -1
- package/en/docusaurus-plugin-content-docs/current/configure/app/tools/postcss.md +1 -1
- package/en/docusaurus-plugin-content-docs/current/configure/app/tools/pug.md +1 -1
- package/en/docusaurus-plugin-content-docs/current/configure/app/tools/sass.md +1 -1
- package/en/docusaurus-plugin-content-docs/current/configure/app/tools/style-loader.md +1 -1
- package/en/docusaurus-plugin-content-docs/current/configure/app/tools/styled-components.md +1 -1
- package/en/docusaurus-plugin-content-docs/current/configure/app/tools/swc.md +42 -0
- package/en/docusaurus-plugin-content-docs/current/configure/app/tools/terser.md +1 -1
- package/en/docusaurus-plugin-content-docs/current/configure/app/tools/ts-checker.md +1 -1
- package/en/docusaurus-plugin-content-docs/current/configure/app/tools/ts-loader.md +1 -1
- package/en/docusaurus-plugin-content-docs/current/configure/app/tools/webpack-chain.md +1 -1
- package/en/docusaurus-plugin-content-docs/current/configure/app/tools/webpack.md +1 -1
- package/en/docusaurus-plugin-content-docs/current/guides/basic-features/builder.md +46 -0
- package/en/docusaurus-plugin-content-docs/current/guides/topic-detail/generator/_category_.json +4 -0
- package/en/docusaurus-plugin-content-docs/current/guides/topic-detail/generator/codesmith/_category_.json +4 -0
- package/en/docusaurus-plugin-content-docs/current/guides/topic-detail/generator/codesmith/api/_category_.json +4 -0
- package/en/docusaurus-plugin-content-docs/current/guides/topic-detail/generator/codesmith/api/app.md +152 -0
- package/en/docusaurus-plugin-content-docs/current/guides/topic-detail/generator/codesmith/api/ejs.md +56 -0
- package/en/docusaurus-plugin-content-docs/current/guides/topic-detail/generator/codesmith/api/fs.md +54 -0
- package/en/docusaurus-plugin-content-docs/current/guides/topic-detail/generator/codesmith/api/git.md +49 -0
- package/en/docusaurus-plugin-content-docs/current/guides/topic-detail/generator/codesmith/api/handlebars.md +58 -0
- package/en/docusaurus-plugin-content-docs/current/guides/topic-detail/generator/codesmith/api/json.md +59 -0
- package/en/docusaurus-plugin-content-docs/current/guides/topic-detail/generator/codesmith/api/npm.md +49 -0
- package/en/docusaurus-plugin-content-docs/current/guides/topic-detail/generator/codesmith/develop.md +52 -0
- package/en/docusaurus-plugin-content-docs/current/guides/topic-detail/generator/codesmith/introduce.md +46 -0
- package/en/docusaurus-plugin-content-docs/current/guides/topic-detail/generator/codesmith/run-in-js.md +48 -0
- package/en/docusaurus-plugin-content-docs/current/guides/topic-detail/generator/codesmith/structure.md +87 -0
- package/en/docusaurus-plugin-content-docs/current/guides/topic-detail/generator/config/_category_.json +4 -0
- package/en/docusaurus-plugin-content-docs/current/guides/topic-detail/generator/config/common.md +106 -0
- package/en/docusaurus-plugin-content-docs/current/guides/topic-detail/generator/config/module.md +39 -0
- package/en/docusaurus-plugin-content-docs/current/guides/topic-detail/generator/config/monorepo.md +28 -0
- package/en/docusaurus-plugin-content-docs/current/guides/topic-detail/generator/config/mwa.md +89 -0
- package/en/docusaurus-plugin-content-docs/current/guides/topic-detail/generator/plugin/_category_.json +4 -0
- package/en/docusaurus-plugin-content-docs/current/guides/topic-detail/generator/plugin/abstract.md +26 -0
- package/en/docusaurus-plugin-content-docs/current/guides/topic-detail/generator/plugin/api/_category_.json +4 -0
- package/en/docusaurus-plugin-content-docs/current/guides/topic-detail/generator/plugin/api/file/_category_.json +4 -0
- package/en/docusaurus-plugin-content-docs/current/guides/topic-detail/generator/plugin/api/file/addFile.md +52 -0
- package/en/docusaurus-plugin-content-docs/current/guides/topic-detail/generator/plugin/api/file/addHelper.md +26 -0
- package/en/docusaurus-plugin-content-docs/current/guides/topic-detail/generator/plugin/api/file/addManyFile.md +58 -0
- package/en/docusaurus-plugin-content-docs/current/guides/topic-detail/generator/plugin/api/file/addPartial.md +26 -0
- package/en/docusaurus-plugin-content-docs/current/guides/topic-detail/generator/plugin/api/file/introduce.md +38 -0
- package/en/docusaurus-plugin-content-docs/current/guides/topic-detail/generator/plugin/api/file/rmDir.md +24 -0
- package/en/docusaurus-plugin-content-docs/current/guides/topic-detail/generator/plugin/api/file/rmFile.md +24 -0
- package/en/docusaurus-plugin-content-docs/current/guides/topic-detail/generator/plugin/api/file/updateJSONFile.md +54 -0
- package/en/docusaurus-plugin-content-docs/current/guides/topic-detail/generator/plugin/api/file/updateModernConfig.md +26 -0
- package/en/docusaurus-plugin-content-docs/current/guides/topic-detail/generator/plugin/api/file/updateTextRawFile.md +33 -0
- package/en/docusaurus-plugin-content-docs/current/guides/topic-detail/generator/plugin/api/git/_category_.json +4 -0
- package/en/docusaurus-plugin-content-docs/current/guides/topic-detail/generator/plugin/api/git/gitAddAndCommit.md +20 -0
- package/en/docusaurus-plugin-content-docs/current/guides/topic-detail/generator/plugin/api/git/initGitRepo.md +16 -0
- package/en/docusaurus-plugin-content-docs/current/guides/topic-detail/generator/plugin/api/git/isInGitRepo.md +16 -0
- package/en/docusaurus-plugin-content-docs/current/guides/topic-detail/generator/plugin/api/hook/_category_.json +4 -0
- package/en/docusaurus-plugin-content-docs/current/guides/topic-detail/generator/plugin/api/hook/afterForged.md +35 -0
- package/en/docusaurus-plugin-content-docs/current/guides/topic-detail/generator/plugin/api/hook/onForged.md +36 -0
- package/en/docusaurus-plugin-content-docs/current/guides/topic-detail/generator/plugin/api/info/_category_.json +4 -0
- package/en/docusaurus-plugin-content-docs/current/guides/topic-detail/generator/plugin/api/info/isFileExit.md +22 -0
- package/en/docusaurus-plugin-content-docs/current/guides/topic-detail/generator/plugin/api/info/locale.md +17 -0
- package/en/docusaurus-plugin-content-docs/current/guides/topic-detail/generator/plugin/api/info/readDir.md +22 -0
- package/en/docusaurus-plugin-content-docs/current/guides/topic-detail/generator/plugin/api/input/_category_.json +4 -0
- package/en/docusaurus-plugin-content-docs/current/guides/topic-detail/generator/plugin/api/input/addInputAfter.md +57 -0
- package/en/docusaurus-plugin-content-docs/current/guides/topic-detail/generator/plugin/api/input/addInputBefore.md +56 -0
- package/en/docusaurus-plugin-content-docs/current/guides/topic-detail/generator/plugin/api/input/setInput.md +42 -0
- package/en/docusaurus-plugin-content-docs/current/guides/topic-detail/generator/plugin/api/input/setInputValue.md +30 -0
- package/en/docusaurus-plugin-content-docs/current/guides/topic-detail/generator/plugin/api/input/type.md +65 -0
- package/en/docusaurus-plugin-content-docs/current/guides/topic-detail/generator/plugin/api/introduce.md +91 -0
- package/en/docusaurus-plugin-content-docs/current/guides/topic-detail/generator/plugin/api/new/_category_.json +4 -0
- package/en/docusaurus-plugin-content-docs/current/guides/topic-detail/generator/plugin/api/new/createElement.md +33 -0
- package/en/docusaurus-plugin-content-docs/current/guides/topic-detail/generator/plugin/api/new/createSubProject.md +35 -0
- package/en/docusaurus-plugin-content-docs/current/guides/topic-detail/generator/plugin/api/new/enableFunc.md +44 -0
- package/en/docusaurus-plugin-content-docs/current/guides/topic-detail/generator/plugin/api/new/introduce.md +15 -0
- package/en/docusaurus-plugin-content-docs/current/guides/topic-detail/generator/plugin/api/npm/_category_.json +4 -0
- package/en/docusaurus-plugin-content-docs/current/guides/topic-detail/generator/plugin/api/npm/install.md +18 -0
- package/en/docusaurus-plugin-content-docs/current/guides/topic-detail/generator/plugin/develop.md +125 -0
- package/en/docusaurus-plugin-content-docs/current/guides/topic-detail/generator/plugin/use.md +61 -0
- package/en/docusaurus-plugin-content-docs/current/guides/topic-detail/generator/project.md +118 -0
- package/en/docusaurus-plugin-content-docs/current.json +57 -21
- package/package.json +3 -3
- package/scripts/config.ts +2 -2
- package/scripts/summary.en.json +1 -1
- package/scripts/summary.zh.json +1 -1
- package/zh/apis/app/commands/new.md +0 -3
- package/zh/apis/app/hooks/server/test.md +2 -2
- package/zh/apis/app/runtime/app/_category_.json +1 -1
- package/zh/apis/app/runtime/bff/_category_.json +1 -1
- package/zh/apis/app/runtime/core/_category_.json +1 -1
- package/zh/apis/app/runtime/core/bootstrap.md +17 -3
- package/zh/apis/app/runtime/model/_category_.json +1 -1
- package/zh/apis/app/runtime/model/create-app.md +1 -1
- package/zh/apis/app/runtime/model/use-store.md +1 -23
- package/zh/apis/app/runtime/router/_category_.json +1 -1
- package/zh/apis/app/runtime/ssr/_category_.json +1 -1
- package/zh/apis/app/runtime/testing/_category_.json +1 -1
- package/zh/apis/app/runtime/utility/_category_.json +1 -1
- package/zh/apis/app/runtime/web-server/_category_.json +1 -1
- package/zh/apis/app/runtime/web-server/hook.md +4 -4
- package/zh/apis/app/runtime/web-server/middleware.md +4 -4
- package/zh/components/reduck-migration.md +1 -0
- package/zh/configure/app/dev/asset-prefix.md +1 -1
- package/zh/configure/app/dev/hmr.md +1 -1
- package/zh/configure/app/dev/https.md +1 -1
- package/zh/configure/app/dev/port.md +1 -1
- package/zh/configure/app/dev/progress-bar.md +1 -1
- package/zh/configure/app/dev/start-url.md +1 -1
- package/zh/configure/app/experiments/_category_.json +4 -0
- package/zh/configure/app/experiments/lazy-compilation.md +1 -1
- package/zh/configure/app/html/_category_.json +4 -0
- package/zh/configure/app/html/app-icon.md +1 -1
- package/zh/configure/app/html/crossorigin.md +1 -1
- package/zh/configure/app/html/disable-html-folder.md +1 -1
- package/zh/configure/app/html/favicon-by-entries.md +1 -1
- package/zh/configure/app/html/favicon.md +1 -1
- package/zh/configure/app/html/inject-by-entries.md +1 -1
- package/zh/configure/app/html/inject.md +1 -1
- package/zh/configure/app/html/meta-by-entries.md +1 -1
- package/zh/configure/app/html/meta.md +1 -1
- package/zh/configure/app/html/mount-id.md +1 -1
- package/zh/configure/app/html/template-by-entries.md +1 -1
- package/zh/configure/app/html/template-parameters-by-entries.md +1 -1
- package/zh/configure/app/html/template-parameters.md +1 -1
- package/zh/configure/app/html/template.md +1 -1
- package/zh/configure/app/html/title-by-entries.md +1 -1
- package/zh/configure/app/html/title.md +1 -1
- package/zh/configure/app/output/asset-prefix.md +1 -1
- package/zh/configure/app/output/assets-retry.md +1 -1
- package/zh/configure/app/output/charset.md +1 -1
- package/zh/configure/app/output/clean-dist-path.md +1 -1
- package/zh/configure/app/output/convert-to-rem.md +1 -1
- package/zh/configure/app/output/copy.md +1 -1
- package/zh/configure/app/output/css-module-local-ident-name.md +1 -1
- package/zh/configure/app/output/data-uri-limit.md +1 -1
- package/zh/configure/app/output/disable-css-extract.md +12 -0
- package/zh/configure/app/output/disable-css-module-extension.md +1 -1
- package/zh/configure/app/output/disable-filename-hash.md +1 -1
- package/zh/configure/app/output/disable-inline-runtime-chunk.md +1 -1
- package/zh/configure/app/output/disable-minimize.md +1 -1
- package/zh/configure/app/output/disable-source-map.md +1 -1
- package/zh/configure/app/output/disable-ts-checker.md +1 -1
- package/zh/configure/app/output/dist-path.md +1 -1
- package/zh/configure/app/output/enable-asset-fallback.md +1 -1
- package/zh/configure/app/output/enable-asset-manifest.md +1 -1
- package/zh/configure/app/output/enable-css-module-tsdeclaration.md +1 -1
- package/zh/configure/app/output/enable-inline-scripts.md +1 -1
- package/zh/configure/app/output/enable-inline-styles.md +1 -1
- package/zh/configure/app/output/enable-latest-decorators.md +1 -1
- package/zh/configure/app/output/externals.md +1 -1
- package/zh/configure/app/output/filename.md +1 -1
- package/zh/configure/app/output/legal-comments.md +1 -1
- package/zh/configure/app/output/override-browserslist.md +1 -1
- package/zh/configure/app/output/polyfill.md +1 -1
- package/zh/configure/app/output/ssg.md +118 -114
- package/zh/configure/app/output/svg-default-export.md +1 -1
- package/zh/configure/app/performance/_category_.json +4 -0
- package/zh/configure/app/performance/build-cache.md +1 -1
- package/zh/configure/app/performance/bundle-analyze.md +1 -1
- package/zh/configure/app/performance/chunk-split.md +1 -1
- package/zh/configure/app/performance/print-file-size.md +1 -1
- package/zh/configure/app/performance/profile.md +1 -1
- package/zh/configure/app/performance/remove-console.md +1 -1
- package/zh/configure/app/performance/remove-moment-locale.md +1 -1
- package/zh/configure/app/plugins.md +1 -1
- package/zh/configure/app/runtime/state.md +13 -0
- package/zh/configure/app/security/_category_.json +4 -0
- package/zh/configure/app/security/sri.md +1 -1
- package/zh/configure/app/server/ssr.md +0 -2
- package/zh/configure/app/source/alias.md +1 -1
- package/zh/configure/app/source/compile-js-data-uri.md +1 -1
- package/zh/configure/app/source/define.md +1 -1
- package/zh/configure/app/source/exclude.md +1 -1
- package/zh/configure/app/source/global-vars.md +1 -1
- package/zh/configure/app/source/include.md +1 -1
- package/zh/configure/app/source/module-scopes.md +1 -1
- package/zh/configure/app/source/pre-entry.md +1 -1
- package/zh/configure/app/source/resolve-extension-prefix.md +1 -1
- package/zh/configure/app/source/resolve-main-fields.md +1 -1
- package/zh/configure/app/tools/autoprefixer.md +1 -1
- package/zh/configure/app/tools/babel.md +1 -1
- package/zh/configure/app/tools/css-extract.md +1 -1
- package/zh/configure/app/tools/css-loader.md +1 -1
- package/zh/configure/app/tools/dev-server.md +1 -1
- package/zh/configure/app/tools/html-plugin.md +1 -1
- package/zh/configure/app/tools/inspector.md +1 -1
- package/zh/configure/app/tools/less.md +1 -1
- package/zh/configure/app/tools/minify-css.md +1 -1
- package/zh/configure/app/tools/postcss.md +1 -1
- package/zh/configure/app/tools/pug.md +1 -1
- package/zh/configure/app/tools/sass.md +1 -1
- package/zh/configure/app/tools/style-loader.md +1 -1
- package/zh/configure/app/tools/styled-components.md +1 -1
- package/zh/configure/app/tools/swc.md +42 -0
- package/zh/configure/app/tools/terser.md +1 -1
- package/zh/configure/app/tools/ts-checker.md +1 -1
- package/zh/configure/app/tools/ts-loader.md +1 -1
- package/zh/configure/app/tools/webpack-chain.md +1 -1
- package/zh/configure/app/tools/webpack.md +1 -1
- package/zh/guides/advanced-features/bff/_category_.json +5 -1
- package/zh/guides/advanced-features/bff/bff-proxy.md +5 -3
- package/zh/guides/advanced-features/bff/frameworks.md +72 -51
- package/zh/guides/advanced-features/bff/function.md +16 -30
- package/zh/guides/advanced-features/bff/index.md +20 -0
- package/zh/guides/advanced-features/bff/type.md +43 -0
- package/zh/guides/advanced-features/custom-app.md +69 -1
- package/zh/guides/advanced-features/ssg.md +74 -63
- package/zh/guides/advanced-features/ssr.md +74 -11
- package/zh/guides/advanced-features/web-server.md +21 -110
- package/zh/guides/basic-features/builder.md +46 -0
- package/zh/guides/basic-features/css/_category_.json +1 -1
- package/zh/guides/basic-features/css/less-sass.md +1 -14
- package/zh/guides/basic-features/data-fetch.md +62 -1
- package/zh/guides/basic-features/env-vars.md +122 -41
- package/zh/guides/basic-features/routes.md +264 -0
- package/zh/guides/concept/entries.md +112 -0
- package/zh/guides/concept/lifecycle.md +10 -0
- package/zh/guides/get-started/quick-start.md +199 -1
- package/zh/guides/get-started/upgrade.md +75 -1
- package/zh/guides/topic-detail/framework-plugin/extend.md +3 -4
- package/zh/{apis/app/runtime/plugin/hook-api.md → guides/topic-detail/framework-plugin/hook-list.md} +42 -135
- package/zh/{apis/app/runtime/plugin → guides/topic-detail/framework-plugin}/hook.md +2 -3
- package/zh/guides/topic-detail/framework-plugin/implement.md +21 -10
- package/zh/guides/topic-detail/framework-plugin/introduction.md +49 -0
- package/{en/docusaurus-plugin-content-docs/current/apis/app/runtime/plugin → zh/guides/topic-detail/framework-plugin}/plugin-api.md +3 -4
- package/zh/guides/topic-detail/framework-plugin/relationship.md +2 -3
- package/zh/guides/topic-detail/generator/codesmith/api/_category_.json +4 -0
- package/zh/guides/topic-detail/generator/codesmith/api/app.md +152 -0
- package/zh/guides/topic-detail/generator/codesmith/api/ejs.md +56 -0
- package/zh/guides/topic-detail/generator/codesmith/api/fs.md +54 -0
- package/zh/guides/topic-detail/generator/codesmith/api/git.md +48 -0
- package/zh/guides/topic-detail/generator/codesmith/api/handlebars.md +56 -0
- package/zh/guides/topic-detail/generator/codesmith/api/json.md +58 -0
- package/zh/guides/topic-detail/generator/codesmith/api/npm.md +45 -0
- package/zh/guides/topic-detail/generator/codesmith/develop.md +52 -0
- package/zh/guides/topic-detail/generator/codesmith/introduce.md +42 -1
- package/zh/guides/topic-detail/generator/codesmith/run-in-js.md +48 -0
- package/zh/guides/topic-detail/generator/codesmith/structure.md +86 -0
- package/zh/guides/topic-detail/generator/config/mwa.md +4 -8
- package/zh/guides/topic-detail/generator/plugin/api/file/addFile.md +1 -1
- package/zh/guides/topic-detail/generator/plugin/api/file/addHelper.md +1 -1
- package/zh/guides/topic-detail/generator/plugin/api/file/addPartial.md +2 -2
- package/zh/guides/topic-detail/generator/plugin/api/file/introduce.md +1 -1
- package/zh/guides/topic-detail/generator/plugin/api/file/rmDir.md +1 -1
- package/zh/guides/topic-detail/generator/plugin/api/file/rmFile.md +1 -1
- package/zh/guides/topic-detail/generator/plugin/api/file/updateJSONFile.md +3 -2
- package/zh/guides/topic-detail/generator/plugin/api/file/updateModernConfig.md +2 -2
- package/zh/guides/topic-detail/generator/plugin/api/file/updateTextRawFile.md +1 -1
- package/zh/guides/topic-detail/generator/plugin/api/hook/afterForged.md +3 -3
- package/zh/guides/topic-detail/generator/plugin/api/hook/onForged.md +3 -3
- package/zh/guides/topic-detail/generator/plugin/api/input/addInputAfter.md +1 -1
- package/zh/guides/topic-detail/generator/plugin/api/input/addInputBefore.md +1 -1
- package/zh/guides/topic-detail/generator/plugin/api/input/type.md +1 -1
- package/zh/guides/topic-detail/generator/plugin/api/new/createElement.md +1 -1
- package/zh/guides/topic-detail/generator/plugin/api/new/createSubProject.md +1 -1
- package/zh/guides/topic-detail/generator/plugin/api/new/enableFunc.md +1 -1
- package/zh/guides/topic-detail/generator/plugin/api/npm/install.md +1 -1
- package/zh/guides/topic-detail/generator/plugin/develop.md +11 -7
- package/zh/guides/topic-detail/model/quick-start.md +4 -0
- package/zh/guides/topic-detail/monorepo/sub-project-interface.md +0 -2
- package/zh/tutorials/first-app/c01-getting-started/1.1-prerequisites.md +2 -2
- package/zh/tutorials/first-app/c01-getting-started/1.2-minimal-mwa.md +2 -2
- package/zh/tutorials/first-app/c01-getting-started/1.4-enable-ssr.md +5 -2
- package/zh/tutorials/first-app/c02-generator-and-studio/2.1-generator.md +0 -8
- package/zh/tutorials/first-app/c02-generator-and-studio/2.2-boilerplates.md +12 -6
- package/zh/tutorials/first-app/c02-generator-and-studio/2.3-configuration.md +2 -4
- package/zh/tutorials/first-app/c03-ide/3.1-setting-up.md +1 -1
- package/zh/tutorials/first-app/c03-ide/3.2-hints-in-ide.md +44 -50
- package/zh/tutorials/first-app/c03-ide/3.3-autofix-in-ide.md +1 -1
- package/zh/tutorials/first-app/c03-ide/3.4-autofix-in-cli.md +4 -4
- package/zh/tutorials/first-app/c04-es6-plus-and-ts/4.1-use-es6-plus.md +8 -21
- package/zh/tutorials/first-app/c04-es6-plus-and-ts/4.2-use-typescript.md +37 -13
- package/zh/tutorials/first-app/c05-component/5.1-use-ui-library.md +3 -13
- package/zh/tutorials/first-app/c05-component/5.2-use-standalone-component.md +1 -21
- package/zh/tutorials/first-app/c06-css-and-component/6.1-css-in-js.md +9 -9
- package/zh/tutorials/first-app/c06-css-and-component/6.2-utility-class.md +9 -14
- package/zh/tutorials/first-app/c06-css-and-component/6.3-postcss.md +7 -7
- package/zh/tutorials/first-app/c06-css-and-component/6.4-design-system.md +1 -1
- package/zh/tutorials/first-app/c06-css-and-component/6.5-storybook.md +2 -2
- package/zh/tutorials/first-app/c06-css-and-component/6.6-testing.md +8 -17
- package/zh/tutorials/first-app/c07-app-entry/7.1-intro.md +24 -19
- package/zh/tutorials/first-app/c07-app-entry/7.2-add-entry-in-cli.md +31 -35
- package/zh/tutorials/first-app/c07-app-entry/7.3-manage-entries-by-hand.md +4 -9
- package/zh/tutorials/first-app/c08-client-side-routing/8.1-code-based-routing.md +66 -63
- package/zh/tutorials/first-app/c09-bff/9.2-enable-bff.md +35 -33
- package/zh/tutorials/first-app/c09-bff/9.3-fetch-bff.md +28 -102
- package/zh/tutorials/first-app/c10-model/10.1-application-architecture.md +4 -6
- package/zh/tutorials/first-app/c10-model/10.2-add-model.md +3 -3
- package/zh/tutorials/first-app/c10-model/10.3-use-model.md +21 -20
- package/zh/tutorials/first-app/c10-model/10.4-testing.md +2 -2
- package/zh/tutorials/first-app/c11-container/11.1-use-model-with-app-state.md +34 -68
- package/zh/tutorials/first-app/c11-container/11.2-add-container.md +40 -37
- package/zh/tutorials/first-app/c11-container/11.3-use-loader.md +6 -4
- package/zh/tutorials/first-app/c11-container/11.4-testing.md +2 -2
- package/zh/tutorials/foundations/introduction.md +1 -1
- package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/default-alias.md +0 -25
- package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/env.md +0 -72
- package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/plugin/_category_.json +0 -4
- package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/plugin/abstract.md +0 -26
- package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/plugin/hook-api.md +0 -896
- package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/plugin/hook.md +0 -170
- package/zh/apis/app/runtime/default-alias.md +0 -23
- package/zh/apis/app/runtime/env.md +0 -70
- package/zh/apis/app/runtime/plugin/_category_.json +0 -4
- package/zh/apis/app/runtime/plugin/abstract.md +0 -26
- package/zh/apis/app/runtime/plugin/plugin-api.md +0 -117
- package/zh/components/deploy.md +0 -60
- package/zh/components/dev-ide.md +0 -1
- package/zh/components/entry-name.md +0 -15
- package/zh/components/env-prepare.md +0 -1
- package/zh/components/launch-bff-choices.md +0 -6
- package/zh/guides/advanced-features/bff/bff-server.md +0 -142
- package/zh/guides/advanced-features/typescript.md +0 -4
- package/zh/guides/basic-features/image.md +0 -43
- package/zh/guides/concept/integrated.md +0 -4
- package/zh/guides/concept/solutions.md +0 -4
- package/zh/guides/topic-detail/compile-speed.md +0 -182
- package/zh/guides/topic-detail/framework-plugin/abstract.md +0 -27
- package/zh/guides/troubleshooting/compile.md +0 -379
- package/zh/tutorials/first-app/c08-client-side-routing/8.2-file-based-routing.md +0 -318
@@ -1,43 +0,0 @@
|
|
1
|
-
---
|
2
|
-
title: 图片资源
|
3
|
-
sidebar_position: 4
|
4
|
-
---
|
5
|
-
|
6
|
-
## JS 中使用图片
|
7
|
-
|
8
|
-
JS 文件中引入的图片资源会返回解析之后的 URL:
|
9
|
-
|
10
|
-
```js title=src/App.jsx
|
11
|
-
import logoUrl from './logo.png';
|
12
|
-
|
13
|
-
console.log(logoUrl); // 输出: '/src/logo.png';
|
14
|
-
```
|
15
|
-
|
16
|
-
## Base64 编码内联
|
17
|
-
|
18
|
-
默认情况下,小于 10kb 的图片、字体文件,会经过 Base64 编码,内联进页面,不会再发送独立的请求。
|
19
|
-
|
20
|
-
可以通过配置 [`output.dataUriLimit`](/docs/configure/app/output/data-uri-limit) 修改这个阈值。
|
21
|
-
|
22
|
-
## JS 中使用 SVG
|
23
|
-
|
24
|
-
针对 SVG 资源,默认启用了 [SVGR](https://react-svgr.com/),可以通过 React 组件的形式导入:
|
25
|
-
|
26
|
-
```js title=App.jsx
|
27
|
-
import logoUrl, { ReactComponent as LogoComponent } from './logo.svg';
|
28
|
-
```
|
29
|
-
|
30
|
-
## CSS 中使用图片
|
31
|
-
|
32
|
-
在 CSS 文件中既可以通过相对路径也可以通过别名的方式引入图片:
|
33
|
-
|
34
|
-
```css
|
35
|
-
.logo {
|
36
|
-
background: url('./foo.png');
|
37
|
-
}
|
38
|
-
|
39
|
-
/** or **/
|
40
|
-
.logo {
|
41
|
-
background: url('@/foo.png');
|
42
|
-
}
|
43
|
-
```
|
@@ -1,182 +0,0 @@
|
|
1
|
-
---
|
2
|
-
title: 提升编译速度
|
3
|
-
sidebar_position: 9
|
4
|
-
---
|
5
|
-
|
6
|
-
Modern.js 默认内置了一系列的编译性能优化策略,但是随着业务场景变复杂、仓库的代码量增大,在使用过程中可能会遇到一些编译性能的问题。
|
7
|
-
|
8
|
-
本文档提供了一些可选的提速策略,**开发者可以根据实际场景选取其中的部分策略**,从而进一步提升编译速度。
|
9
|
-
|
10
|
-
## 通用优化策略
|
11
|
-
|
12
|
-
以下是一些通用的优化策略,对 `modern dev` 和 `modern build` 均有提速效果,其中部分策略对包体积也有优化。
|
13
|
-
|
14
|
-
### 减少重复依赖
|
15
|
-
|
16
|
-
在实际项目中,会存在某些第三方依赖被安装了多个版本的现象。重复依赖会导致包体积变大、编译速度变慢。
|
17
|
-
|
18
|
-
我们可以通过社区中的一些工具来自动消除重复依赖,比如 [yarn-deduplicate](https://github.com/scinos/yarn-deduplicate)。
|
19
|
-
|
20
|
-
```bash
|
21
|
-
npx yarn-deduplicate && yarn
|
22
|
-
```
|
23
|
-
|
24
|
-
如果你在使用 `pnpm`,可以考虑通过**重新生成 lock 文件**来减少重复依赖,
|
25
|
-
|
26
|
-
```bash
|
27
|
-
rm -rf ./node_modules pnpm-lock.yaml && pnpm install
|
28
|
-
```
|
29
|
-
|
30
|
-
:::info
|
31
|
-
删除 lock 文件会使项目中的依赖版本自动升级到指定范围下的最新版,请进行充分的测试。
|
32
|
-
:::
|
33
|
-
|
34
|
-
### 替换体积较大的依赖
|
35
|
-
|
36
|
-
建议将项目中体积较大的第三方依赖替换为更轻量的库,比如将 [moment](https://momentjs.com/) 替换为 [day.js](https://day.js.org/)。
|
37
|
-
|
38
|
-
如果不清楚项目中哪些三方依赖的体积较大,可以在执行构建时添加 `--analyze` 参数:
|
39
|
-
|
40
|
-
```bash
|
41
|
-
npx modern build --analyze
|
42
|
-
```
|
43
|
-
|
44
|
-
该参数会生成一个分析构建产物体积的 HTML 文件,手动在浏览器中打开该文件,可以看到打包产物的瓦片图。区块的面积越大,说明该模块的体积越大。
|
45
|
-
|
46
|
-
<img src="https://lf3-static.bytednsdoc.com/obj/eden-cn/aphqeh7uhohpquloj/modern-js/mwa-build-analyze-8784f762c1ab0cb20935829d5f912c4c.png" />
|
47
|
-
|
48
|
-
### 避免使用 ts-loader
|
49
|
-
|
50
|
-
默认情况下,Modern.js 使用 Babel 编译 TS 文件,开启 `output.enableTsLoader` 选项后,会使用 `ts-loader` 编译 TS 文件。
|
51
|
-
|
52
|
-
由于 `ts-loader` 需要进行额外的语法解析和类型检查,因此会导致项目编译速度变慢,请避免使用。
|
53
|
-
|
54
|
-
```typescript title="modern.config.ts"
|
55
|
-
export default defineConfig({
|
56
|
-
output: {
|
57
|
-
// 移除这项配置
|
58
|
-
enableTsLoader: true,
|
59
|
-
},
|
60
|
-
});
|
61
|
-
```
|
62
|
-
|
63
|
-
详见 [tools.tsLoader 文档](/docs/configure/app/tools/ts-loader)。
|
64
|
-
|
65
|
-
### 提升 Browserslist 范围
|
66
|
-
|
67
|
-
**减少 Polyfill 的代码量可以提升编译速度。**Modern.js 会根据项目的 Browserslist 配置范围进行代码编译,并注入相应的 Polyfill。如果项目对兼容性的要求较低,可以根据实际情况,提升 Browserslist 范围,从而减少 Polyfill 的代码量。
|
68
|
-
|
69
|
-
默认的 Browserslist 配置为:
|
70
|
-
|
71
|
-
```js
|
72
|
-
['> 0.01%', 'not dead', 'not op_mini all'];
|
73
|
-
```
|
74
|
-
|
75
|
-
比如只兼容 Chrome 53 以上的浏览器,可以改成:
|
76
|
-
|
77
|
-
```js
|
78
|
-
['Chrome >= 53'];
|
79
|
-
```
|
80
|
-
|
81
|
-
详见 [客户端兼容性 - Browserslist 配置](/docs/guides/advanced-features/compatibility#browserslist-配置)。
|
82
|
-
|
83
|
-
### 按需引入 Polyfill
|
84
|
-
|
85
|
-
明确第三方依赖不需要 Polyfill 的情况下,可以将 `output.polyfill` 设置为 `usage`,根据代码中使用到的语法,按需注入所需的 Polyfill 代码,从而减少 Polyfill 的代码量。
|
86
|
-
|
87
|
-
```typescript title="modern.config.ts"
|
88
|
-
export default defineConfig({
|
89
|
-
output: {
|
90
|
-
polyfill: 'usage',
|
91
|
-
},
|
92
|
-
});
|
93
|
-
```
|
94
|
-
|
95
|
-
详见 [客户端兼容性 - Polyfill 模式](/docs/guides/advanced-features/compatibility#polyfill-模式)。
|
96
|
-
|
97
|
-
## dev 优化策略
|
98
|
-
|
99
|
-
以下是针对 `modern dev` 进行提速的策略。
|
100
|
-
|
101
|
-
### 调整开发环境 SourceMap 格式
|
102
|
-
|
103
|
-
为了提供良好的调试体验,Modern.js 在开发环境下默认使用 webpack 提供的 `cheap-module-source-map` 格式 SourceMap。
|
104
|
-
|
105
|
-
由于生成高质量的 SourceMap 需要额外的性能开销,通过调整开发环境的 SourceMap 格式,可以提升 dev 编译速度。
|
106
|
-
|
107
|
-
比如禁用 SourceMap:
|
108
|
-
|
109
|
-
```typescript title="modern.config.ts"
|
110
|
-
export default defineConfig({
|
111
|
-
tools: {
|
112
|
-
webpackChain(chain, { env }) {
|
113
|
-
if (env === 'development') {
|
114
|
-
chain.devtool(false);
|
115
|
-
}
|
116
|
-
},
|
117
|
-
},
|
118
|
-
});
|
119
|
-
```
|
120
|
-
|
121
|
-
或是把开发环境的 SourceMap 格式设置为开销最小的 `eval` 格式:
|
122
|
-
|
123
|
-
```typescript title="modern.config.ts"
|
124
|
-
export default defineConfig({
|
125
|
-
tools: {
|
126
|
-
webpackChain(chain, { env }) {
|
127
|
-
if (env === 'development') {
|
128
|
-
chain.devtool('eval');
|
129
|
-
}
|
130
|
-
},
|
131
|
-
},
|
132
|
-
});
|
133
|
-
```
|
134
|
-
|
135
|
-
> 关于不同 SourceMap 格式之间的详细差异,请查看 [webpack - devtool](https://webpack.js.org/configuration/devtool/)。
|
136
|
-
|
137
|
-
### 调整开发环境的 Browserslist 范围
|
138
|
-
|
139
|
-
这项优化的原理与「提升 Browserslist 范围」类似,区别在于,我们可以为开发环境和生产环境设置不同的 browserslist,使开发环境下不需要引入额外的 Polyfill 编译逻辑。
|
140
|
-
|
141
|
-
比如在 `package.json` 中添加以下配置,在开发环境下只兼容最新的浏览器,在生产环境下兼容实际需要的浏览器:
|
142
|
-
|
143
|
-
```json
|
144
|
-
{
|
145
|
-
"browserslist": {
|
146
|
-
"production": [">0.2%", "not dead", "not op_mini all"],
|
147
|
-
"development": [
|
148
|
-
"last 1 chrome version",
|
149
|
-
"last 1 firefox version",
|
150
|
-
"last 1 safari version"
|
151
|
-
]
|
152
|
-
}
|
153
|
-
}
|
154
|
-
```
|
155
|
-
|
156
|
-
注意,这项优化策略会导致 `dev` 构建的产物与 `build` 构建的产物存在一定差异。
|
157
|
-
|
158
|
-
## build 优化策略
|
159
|
-
|
160
|
-
以下是针对 `modern build` 进行提速的策略。
|
161
|
-
|
162
|
-
### 禁用生产环境 SourceMap
|
163
|
-
|
164
|
-
如果项目在生产环境下不需要 SourceMap,可以通过 `disableSourceMap` 配置项关闭,从而提升 build 构建的速度。
|
165
|
-
|
166
|
-
```typescript title="modern.config.ts"
|
167
|
-
export default defineConfig({
|
168
|
-
output: {
|
169
|
-
disableSourceMap: true,
|
170
|
-
},
|
171
|
-
});
|
172
|
-
```
|
173
|
-
|
174
|
-
详见 [output.disableSourceMap](/docs/configure/app/output/disable-source-map)。
|
175
|
-
|
176
|
-
### 使用 esbuild 压缩
|
177
|
-
|
178
|
-
Modern.js 基于 esbuild 提供了代码编译和压缩的能力,在大型工程中开启后,**可以大幅度减少代码压缩所需的时间,同时有效避免 OOM (heap out of memory) 问题**。
|
179
|
-
|
180
|
-
使用 esbuild 压缩虽然带来了构建效率上的提升,但 esbuild 的压缩比例是低于 terser 的,因此**构建产物的体积会增大**,请根据业务情况酌情使用(比较适合中后台场景)。
|
181
|
-
|
182
|
-
详见 [tools.esbuild](/docs/configure/app/tools/esbuild)。
|
@@ -1,27 +0,0 @@
|
|
1
|
-
---
|
2
|
-
sidebar_position: 1
|
3
|
-
---
|
4
|
-
|
5
|
-
# 插件可以做什么
|
6
|
-
|
7
|
-
Modern.js 内置了一套插件系统,并基于这套插件系统来管理各个运行流程,Modern.js 的所有工程方案都是通过这套插件实现的,同时也支持开发者通过编写插件来扩展更多功能,适配复杂场景。
|
8
|
-
|
9
|
-
由于 Modern.js 是基于这套插件系统实现的,因此可以说,Modern.js 中的所有能力是都对开发者开放的。包括但不限于:
|
10
|
-
|
11
|
-
- 注册命令
|
12
|
-
- 修改 Modern.js 配置、配置校验 Schema
|
13
|
-
- 修改编译时的 Webpack/Babel/Less/Sass/Tailwind CSS/... 配置
|
14
|
-
- 修改运行时需要渲染的 React 组件、Element
|
15
|
-
- 修改页面路由
|
16
|
-
- 修改服务器路由
|
17
|
-
- 自定义控制台输出
|
18
|
-
- 自定义动态 HTML 模版
|
19
|
-
- 自定义 Node.js 服务器框架
|
20
|
-
- 自定义 React 组件客户端/服务器端渲染
|
21
|
-
- ...
|
22
|
-
|
23
|
-
因此,当 Modern.js 暂时没有覆盖到你所需要的功能或场景时,可以开发一个自定义插件,来实现适配特殊场景的相关功能。
|
24
|
-
|
25
|
-
:::info 补充信息
|
26
|
-
关于 Modern.js 插件 API 的详细介绍,请参考 【[插件 API](/docs/apis/app/runtime/plugin/abstract)】。
|
27
|
-
:::
|
@@ -1,379 +0,0 @@
|
|
1
|
-
---
|
2
|
-
sidebar_position: 1
|
3
|
-
---
|
4
|
-
|
5
|
-
# 编译构建问题
|
6
|
-
|
7
|
-
### 如何配置 Webpack/Babel/PostCSS 等工具?
|
8
|
-
|
9
|
-
请参考 [配置底层工具](/docs/guides/advanced-features/low-level)。
|
10
|
-
|
11
|
-
### 如何自定义 HTML 模板?
|
12
|
-
|
13
|
-
请参考 [自定义 HTML 模板](/docs/guides/basic-features/html)。
|
14
|
-
|
15
|
-
### 如何提升编译构建速度?
|
16
|
-
|
17
|
-
请参考 [提升编译速度](/docs/guides/topic-detail/compile-speed)。
|
18
|
-
|
19
|
-
### 如何查看最终生效的 webpack 配置?
|
20
|
-
|
21
|
-
可以通过 [modern inspect](/docs/apis/app/commands/inspect) 命令来查看最终生效的 webpack 配置。
|
22
|
-
|
23
|
-
---
|
24
|
-
|
25
|
-
### 如何配置组件库按需引入?
|
26
|
-
|
27
|
-
默认情况下,Modern.js 内置了 antd 组件库的按需引入配置。
|
28
|
-
|
29
|
-
如果需要配置其他组件库的按需引入,可以通过 [tools.babel](/docs/configure/app/tools/babel) 配置 [babel-plugin-import](https://github.com/umijs/babel-plugin-import) 插件。
|
30
|
-
|
31
|
-
```ts title="modern.config.ts"
|
32
|
-
export default defineConfig({
|
33
|
-
tools: {
|
34
|
-
babel: (config, { addPlugins }) => {
|
35
|
-
addPlugins([
|
36
|
-
[
|
37
|
-
'babel-plugin-import',
|
38
|
-
{
|
39
|
-
libraryName: 'xxx-components',
|
40
|
-
libraryDirectory: 'es',
|
41
|
-
style: true,
|
42
|
-
},
|
43
|
-
],
|
44
|
-
]);
|
45
|
-
},
|
46
|
-
},
|
47
|
-
});
|
48
|
-
```
|
49
|
-
|
50
|
-
---
|
51
|
-
|
52
|
-
### 如何移除代码中的 console?
|
53
|
-
|
54
|
-
在生产环境构建时,我们可以移除代码中的 `console`,从而避免开发环境的日志被输出到生产环境。
|
55
|
-
|
56
|
-
由于 Modern.js 默认在生产环境使用 [terser](https://github.com/terser/terser) 进行代码压缩,因此我们可以通过 [tools.terser](/docs/configure/app/tools/terser) 配置项来移除 `console`:
|
57
|
-
|
58
|
-
```js title="modern.config.ts"
|
59
|
-
export default defineConfig({
|
60
|
-
tools: {
|
61
|
-
terser: opt => {
|
62
|
-
if (typeof opt.terserOptions?.compress === 'object') {
|
63
|
-
opt.terserOptions.compress.drop_console = true;
|
64
|
-
}
|
65
|
-
},
|
66
|
-
},
|
67
|
-
});
|
68
|
-
```
|
69
|
-
|
70
|
-
如果只希望移除 `console.log` 和 `console.warn`,保留 `console.error`,可以配置为:
|
71
|
-
|
72
|
-
```js title="modern.config.ts"
|
73
|
-
export default defineConfig({
|
74
|
-
tools: {
|
75
|
-
terser: opt => {
|
76
|
-
if (typeof opt.terserOptions?.compress === 'object') {
|
77
|
-
opt.terserOptions.compress.pure_funcs = ['console.log', 'console.warn'];
|
78
|
-
}
|
79
|
-
},
|
80
|
-
},
|
81
|
-
});
|
82
|
-
```
|
83
|
-
|
84
|
-
---
|
85
|
-
|
86
|
-
### 如何清空 webpack 编译缓存?
|
87
|
-
|
88
|
-
默认情况下,Modern.js 的 webpack 编译缓存生成在 `./node_modules/.cache/webpack` 目录下。
|
89
|
-
|
90
|
-
如果需要清空本地的编译缓存,可以执行以下命令:
|
91
|
-
|
92
|
-
```bash
|
93
|
-
rm -rf ./node_modules/.cache
|
94
|
-
```
|
95
|
-
|
96
|
-
---
|
97
|
-
|
98
|
-
### 如何配置静态资源的 CDN 路径?
|
99
|
-
|
100
|
-
如果需要将 JS、CSS 等静态资源上传到 CDN 使用,那么可以通过 [output.assetPrefix](/docs/configure/app/output/asset-prefix) 配置来设置静态资源的 URL 前缀。
|
101
|
-
|
102
|
-
```typescript title="modern.config.ts"
|
103
|
-
import { defineConfig } from '@modern-js/app-tools';
|
104
|
-
|
105
|
-
export default defineConfig({
|
106
|
-
output: {
|
107
|
-
assetPrefix: 'https://cdn.example.com/assets/',
|
108
|
-
},
|
109
|
-
});
|
110
|
-
```
|
111
|
-
|
112
|
-
---
|
113
|
-
|
114
|
-
### 如何在编译过程中进行 ESLint 代码校验?
|
115
|
-
|
116
|
-
出于编译性能的考虑,Modern.js 默认不会在编译过程中进行 ESLint 校验,如果需要该功能,可以手动安装并注册社区中的 [eslint-webpack-plugin](https://github.com/webpack-contrib/eslint-webpack-plugin)。
|
117
|
-
|
118
|
-
注册该插件的示例代码如下,更详细的用法请参考 [eslint-webpack-plugin](https://github.com/webpack-contrib/eslint-webpack-plugin) 文档。
|
119
|
-
|
120
|
-
```typescript title="modern.config.ts"
|
121
|
-
import { defineConfig } from '@modern-js/app-tools';
|
122
|
-
import ESLintPlugin from 'eslint-webpack-plugin';
|
123
|
-
|
124
|
-
export default defineConfig({
|
125
|
-
tools: {
|
126
|
-
webpackChain(chain) {
|
127
|
-
chain.plugin('eslint-plugin').use(ESLintPlugin, [
|
128
|
-
{
|
129
|
-
extensions: ['.js', '.ts', '.jsx', 'tsx', '.mjs'],
|
130
|
-
},
|
131
|
-
]);
|
132
|
-
},
|
133
|
-
},
|
134
|
-
});
|
135
|
-
```
|
136
|
-
|
137
|
-
---
|
138
|
-
|
139
|
-
### 如何配置 SRI 校验?
|
140
|
-
|
141
|
-
在 Modern.js 中,需要自主引入社区中的 [webpack-subresource-integrity](https://github.com/waysact/webpack-subresource-integrity) 插件来开启 SRI 校验。
|
142
|
-
|
143
|
-
配置 [webpack-subresource-integrity](https://github.com/waysact/webpack-subresource-integrity) 的示例如下:
|
144
|
-
|
145
|
-
```typescript title="modern.config.ts"
|
146
|
-
import { defineConfig } from '@modern-js/app-tools';
|
147
|
-
import { SubresourceIntegrityPlugin } from 'webpack-subresource-integrity';
|
148
|
-
|
149
|
-
export default defineConfig({
|
150
|
-
tools: {
|
151
|
-
webpackChain(chain) {
|
152
|
-
chain.output.crossOriginLoading('anonymous');
|
153
|
-
chain.plugin('subresource-integrity').use(SubresourceIntegrityPlugin);
|
154
|
-
},
|
155
|
-
},
|
156
|
-
});
|
157
|
-
```
|
158
|
-
|
159
|
-
:::info SRI
|
160
|
-
子资源完整性 Subresource Integrity(SRI)是专门用来校验资源的一种方案,它读取资源标签中的 integrity 属性,将其中的信息摘要值,和资源实际的信息摘要值进行对比,如果发现无法匹配,那么浏览器就会拒绝执行资源。
|
161
|
-
|
162
|
-
对于 script 标签来说,结果为拒绝执行其中的代码;对于 CSS link 来说,结果为不加载其中的样式。
|
163
|
-
:::
|
164
|
-
|
165
|
-
---
|
166
|
-
|
167
|
-
### Less/Sass 代码没有被正确编译?
|
168
|
-
|
169
|
-
Modern.js 通过插件来编译 Less/Sass 代码,请确认你是否启用了对应的插件。
|
170
|
-
|
171
|
-
- [启用 Less 插件教程](/docs/configure/app/tools/less#启用)
|
172
|
-
- [启用 Sass 插件教程](/docs/configure/app/tools/sass#启用)
|
173
|
-
|
174
|
-
---
|
175
|
-
|
176
|
-
### 在 Monorepo 中引用其他模块,代码没有被正确编译?
|
177
|
-
|
178
|
-
出于编译性能的考虑,默认情况下,Modern.js 不会通过 `babel-loader` 或 `ts-loader` 来编译 `node_modules` 下的文件,也不会编译当前工程目录外部的文件。
|
179
|
-
|
180
|
-
通过 `source.include` 配置项,可以指定需要额外进行编译的目录或模块。
|
181
|
-
|
182
|
-
详见 [source.include 用法介绍](/docs/configure/app/source/include/)。
|
183
|
-
|
184
|
-
---
|
185
|
-
|
186
|
-
### 打包时出现 JavaScript heap out of memory?
|
187
|
-
|
188
|
-
该报错表示打包过程中出现了内存溢出问题,大多数情况下是由于打包的内容较多,超出了 Node.js 默认的内存上限。
|
189
|
-
|
190
|
-
如果出现 OOM 问题,最简单的方法是通过增加内存上限来解决,Node.js 提供了 `--max-old-space-size` 选项来对此进行设置。你可以在 `modern build` 命令前添加 [NODE_OPTIONS](http://nodejs.cn/api/cli/node_options_options.html) 来设置此参数:
|
191
|
-
|
192
|
-
```bash
|
193
|
-
NODE_OPTIONS=--max_old_space_size=16384 modern build
|
194
|
-
```
|
195
|
-
|
196
|
-
参数的值代表内存上限大小(MB),一般情况下设置为 `16384`(16GB)即可。
|
197
|
-
|
198
|
-
Node.js 官方文档中有对以下参数更详细的解释:
|
199
|
-
|
200
|
-
- [NODE_OPTIONS](http://nodejs.cn/api/cli/node_options_options.html)
|
201
|
-
- [--max-old-space-size](http://nodejs.cn/api/cli/max_old_space_size_size_in_megabytes.html)
|
202
|
-
|
203
|
-
除了增加内存上限,通过开启一些编译策略来提升效率也是一个解决方案,详见 [提升编译速度](/docs/guides/topic-detail/compile-speed)。
|
204
|
-
|
205
|
-
---
|
206
|
-
|
207
|
-
### webpack 编译出现 'compilation' argument 报错?
|
208
|
-
|
209
|
-
如果编译时出现以下报错,通常是由于项目中安装了错误的 webpack 版本,或者安装了多个 webpack 版本引起:
|
210
|
-
|
211
|
-
```bash
|
212
|
-
TypeError: The 'compilation' argument must be an instance of Compilation
|
213
|
-
```
|
214
|
-
|
215
|
-
webpack 版本问题有以下几种情况:
|
216
|
-
|
217
|
-
1. 项目的 package.json 中直接声明了 webpack 依赖,并且与 Modern.js 依赖的 webpack 版本范围不同,无法匹配到同一个版本。
|
218
|
-
2. 项目里安装的多个 npm 包都依赖了 webpack,并且它们依赖的 webpack 版本范围不同,无法匹配到同一个版本。
|
219
|
-
3. 由于包管理器的 lock 机制,导致 lock 文件中产生了多个 webpack 版本。
|
220
|
-
|
221
|
-
如果是第一种情况,建议从项目的 package.json 中移除 webpack 依赖。因为 Modern.js 默认封装了 webpack 相关能力,并且会在 `tools.webpack` 配置项中传入 webpack 对象。因此在大多数情况下,不建议在项目中额外安装 webpack 依赖。
|
222
|
-
|
223
|
-
如果是第二种情况,建议看看能否升级某个 npm 包,使其依赖的 webpack 版本范围与 Modern.js 保持一致。也可以通过包管理器的能力来手动统一版本,比如使用 [yarn resolutions](https://classic.yarnpkg.com/lang/en/docs/selective-version-resolutions/) 或 [pnpm overrides](https://pnpm.io/package_json#pnpmoverrides)。
|
224
|
-
|
225
|
-
如果是第三种情况,可以使用第二种情况中提到的两种方法,也可以尝试删除 lock 文件后重新安装来解决。
|
226
|
-
|
227
|
-
:::info
|
228
|
-
删除 lock 文件会使项目中的依赖版本自动升级到指定范围下的最新版,请进行充分的测试。
|
229
|
-
:::
|
230
|
-
|
231
|
-
---
|
232
|
-
|
233
|
-
### Less 文件中的除法不生效?
|
234
|
-
|
235
|
-
Less v4 版本与 v3 版本相比,除法的写法有一些区别:
|
236
|
-
|
237
|
-
```less
|
238
|
-
// Less v3
|
239
|
-
.math {
|
240
|
-
width: 2px / 2; // 1px
|
241
|
-
width: 2px ./ 2; // 1px
|
242
|
-
width: (2px / 2); // 1px
|
243
|
-
}
|
244
|
-
|
245
|
-
// Less v4
|
246
|
-
.math {
|
247
|
-
width: 2px / 2; // 2px / 2
|
248
|
-
width: 2px ./ 2; // 1px
|
249
|
-
width: (2px / 2); // 1px
|
250
|
-
}
|
251
|
-
```
|
252
|
-
|
253
|
-
Modern.js 内置的 Less 版本为 v4,低版本的写法不会生效,请注意区分。
|
254
|
-
|
255
|
-
Less 中除法的写法也可以通过配置项来修改,详见 [Less - Math](https://lesscss.org/usage/#less-options-math)。
|
256
|
-
|
257
|
-
---
|
258
|
-
|
259
|
-
### 编译产物中存在未编译的 ES6+ 代码?
|
260
|
-
|
261
|
-
默认情况下,Modern.js 不会通过 `babel-loader` 或 `ts-loader` 来编译 `node_modules` 下的文件。如果项目引入的 npm 包中含有 ES6+ 语法,会被打包进产物中。
|
262
|
-
|
263
|
-
遇到这种情况时,可以通过 [source.include](/docs/configure/app/source/include) 配置项来指定需要额外进行编译的目录或模块。
|
264
|
-
|
265
|
-
---
|
266
|
-
|
267
|
-
### 编译时报错 `You may need additional loader`?
|
268
|
-
|
269
|
-
如果编译过程中遇到了以下报错提示,表示存在个别文件无法被正确编译。
|
270
|
-
|
271
|
-
```bash
|
272
|
-
Module parse failed: Unexpected token
|
273
|
-
File was processed with these loaders:
|
274
|
-
* some-loader/index.js
|
275
|
-
|
276
|
-
You may need an additional loader to handle the result of these loaders.
|
277
|
-
```
|
278
|
-
|
279
|
-
解决方法:
|
280
|
-
|
281
|
-
- 如果是引用了当前工程外部的 `.ts` 文件,或者是 node_modules 下的 `.ts` 文件,请添加 [source.include](/docs/configure/app/source/include) 配置项,指定需要额外进行编译的文件。
|
282
|
-
- 如果是引用了 Modern.js 不支持的文件格式,请自行配置对应的 webpack loader 进行编译。
|
283
|
-
|
284
|
-
---
|
285
|
-
|
286
|
-
### 打开页面后报错,提示 exports is not defined?
|
287
|
-
|
288
|
-
如果编译正常,但是打开页面后出现 `exports is not defined` 报错,通常是因为在项目中使用 babel 编译了一个 CommonJS 模块,导致 babel 出现异常。
|
289
|
-
|
290
|
-
在正常情况下,Modern.js 是不会使用 babel 来编译 CommonJS 模块的。如果项目中使用了 `source.include` 配置项,或使用了 `tools.babel` 的 `addIncludes` 方法,则可能会把一些 CommonJS 模块加入到 babel 编译中。
|
291
|
-
|
292
|
-
该问题有两种解决方法:
|
293
|
-
|
294
|
-
1. 避免将 CommonJS 模块加入到 babel 编译中。
|
295
|
-
2. 将 babel 的 `sourceType` 配置项设置为 `unambiguous`,示例如下:
|
296
|
-
|
297
|
-
```js
|
298
|
-
export default defineConfig({
|
299
|
-
tools: {
|
300
|
-
babel(config) {
|
301
|
-
config.sourceType = 'unambiguous';
|
302
|
-
},
|
303
|
-
},
|
304
|
-
});
|
305
|
-
```
|
306
|
-
|
307
|
-
将 `sourceType` 设置为 `unambiguous` 可能会产生一些其他影响,请参考 [babel 官方文档](https://babeljs.io/docs/en/options#sourcetype)。
|
308
|
-
|
309
|
-
---
|
310
|
-
|
311
|
-
### 打包后发现 Tree Shaking 没有生效?
|
312
|
-
|
313
|
-
Modern.js 在生产构建时会默认开启 webpack 的 Tree Shaking 功能,Tree Shaking 是否能够生效,取决于业务代码能否满足 webpack 的 Tree Shaking 条件。
|
314
|
-
|
315
|
-
如果你遇到了 Tree Shaking 不生效的问题,可以检查下相关 npm 包的 `sideEffects` 配置是否正确,如果不了解 `sideEffects` 是什么,可以阅读以下两篇文档:
|
316
|
-
|
317
|
-
- [webpack 官方文档 - Tree Shaking](https://webpack.docschina.org/guides/tree-shaking/)
|
318
|
-
- [Tree Shaking 问题排查指南](https://bytedance.feishu.cn/docs/doccn8E1ldDct5uv1EEDQs8Ycwe)
|
319
|
-
|
320
|
-
---
|
321
|
-
|
322
|
-
### 热更新后 React 组件的 state 丢失?
|
323
|
-
|
324
|
-
Modern.js 使用 React 官方的 [Fast Refresh](https://github.com/pmmmwh/react-refresh-webpack-plugin) 能力来进行组件热更新。
|
325
|
-
|
326
|
-
在使用 Fast Refresh 时,要求组件不能为匿名函数,否则热更新后无法保留 React 组件的 state。
|
327
|
-
|
328
|
-
以下写法都是不正确的:
|
329
|
-
|
330
|
-
```js
|
331
|
-
// 错误写法 1
|
332
|
-
export default function () {
|
333
|
-
return <div>Hello World</div>;
|
334
|
-
}
|
335
|
-
|
336
|
-
// 错误写法 2
|
337
|
-
export default () => <div>Hello World</div>;
|
338
|
-
```
|
339
|
-
|
340
|
-
正确的写法为:
|
341
|
-
|
342
|
-
```js
|
343
|
-
// 正确写法 1
|
344
|
-
export default function MyComponent() {
|
345
|
-
return <div>Hello World</div>;
|
346
|
-
}
|
347
|
-
|
348
|
-
// 正确写法 2
|
349
|
-
const MyComponent = () => <div>Hello World</div>
|
350
|
-
|
351
|
-
export default MyComponent;
|
352
|
-
```
|
353
|
-
|
354
|
-
---
|
355
|
-
|
356
|
-
### webpack 编译缓存未生效,应该如何排查?
|
357
|
-
|
358
|
-
Modern.js 默认开启了 webpack 的持久化缓存。
|
359
|
-
|
360
|
-
首次编译完成后,会自动生成缓存文件,并输出到 `./node_modules/.cache/webpack` 目录下。执行第二次编译时,会命中缓存,并大幅度提高编译速度。
|
361
|
-
|
362
|
-
当 `modern.config.ts` 或 `package.json` 等配置文件被修改时,缓存会自动失效。
|
363
|
-
|
364
|
-
如果项目中 webpack 编译缓存一直未生效,可以添加以下配置进行排查:
|
365
|
-
|
366
|
-
```ts
|
367
|
-
export default defineConfig({
|
368
|
-
tools: {
|
369
|
-
webpack(config) {
|
370
|
-
config.infrastructureLogging = {
|
371
|
-
...config.infrastructureLogging,
|
372
|
-
debug: true,
|
373
|
-
};
|
374
|
-
},
|
375
|
-
},
|
376
|
-
});
|
377
|
-
```
|
378
|
-
|
379
|
-
添加以上配置后,webpack 会输出日志用于 debug,请参考 `PackFileCacheStrategy` 相关的日志来了解缓存失效的原因。
|