@modern-js/main-doc 2.0.0-beta.0 → 2.0.0-beta.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (507) hide show
  1. package/.turbo/turbo-build.log +4 -0
  2. package/en/docusaurus-plugin-content-docs/current/apis/app/commands/_category_.json +8 -0
  3. package/en/docusaurus-plugin-content-docs/current/apis/app/commands/build.md +44 -0
  4. package/en/docusaurus-plugin-content-docs/current/apis/app/commands/dev.md +31 -0
  5. package/en/docusaurus-plugin-content-docs/current/apis/app/commands/index.md +12 -0
  6. package/en/docusaurus-plugin-content-docs/current/apis/app/commands/inspect.md +39 -0
  7. package/en/docusaurus-plugin-content-docs/current/apis/app/commands/lint.md +22 -0
  8. package/en/docusaurus-plugin-content-docs/current/apis/app/commands/new.md +59 -0
  9. package/en/docusaurus-plugin-content-docs/current/apis/app/commands/start.md +32 -0
  10. package/en/docusaurus-plugin-content-docs/current/apis/app/commands/test.md +36 -0
  11. package/en/docusaurus-plugin-content-docs/current/apis/app/commands/upgrade.md +21 -0
  12. package/en/docusaurus-plugin-content-docs/current/apis/app/hooks/_category_.json +8 -0
  13. package/en/docusaurus-plugin-content-docs/current/apis/app/hooks/api/_category_.json +4 -0
  14. package/en/docusaurus-plugin-content-docs/current/apis/app/hooks/api/framework/_category_.json +4 -0
  15. package/en/docusaurus-plugin-content-docs/current/apis/app/hooks/api/framework/lambda.md +54 -0
  16. package/en/docusaurus-plugin-content-docs/current/apis/app/hooks/api/functions/_category_.json +4 -0
  17. package/en/docusaurus-plugin-content-docs/current/apis/app/hooks/api/functions/api.md +78 -0
  18. package/en/docusaurus-plugin-content-docs/current/apis/app/hooks/api/functions/app.md +12 -0
  19. package/en/docusaurus-plugin-content-docs/current/apis/app/hooks/api/functions/common.md +10 -0
  20. package/en/docusaurus-plugin-content-docs/current/apis/app/hooks/api/test.md +10 -0
  21. package/en/docusaurus-plugin-content-docs/current/apis/app/hooks/config/_category_.json +4 -0
  22. package/en/docusaurus-plugin-content-docs/current/apis/app/hooks/config/html.md +8 -0
  23. package/en/docusaurus-plugin-content-docs/current/apis/app/hooks/config/icon.md +15 -0
  24. package/en/docusaurus-plugin-content-docs/current/apis/app/hooks/config/mock.md +6 -0
  25. package/en/docusaurus-plugin-content-docs/current/apis/app/hooks/config/public.md +28 -0
  26. package/en/docusaurus-plugin-content-docs/current/apis/app/hooks/config/storybook.md +12 -0
  27. package/en/docusaurus-plugin-content-docs/current/apis/app/hooks/config/upload.md +42 -0
  28. package/en/docusaurus-plugin-content-docs/current/apis/app/hooks/index.md +7 -0
  29. package/en/docusaurus-plugin-content-docs/current/apis/app/hooks/modern-config.md +8 -0
  30. package/en/docusaurus-plugin-content-docs/current/apis/app/hooks/server/_category_.json +4 -0
  31. package/en/docusaurus-plugin-content-docs/current/apis/app/hooks/server/index_.md +14 -0
  32. package/en/docusaurus-plugin-content-docs/current/apis/app/hooks/server/test.md +10 -0
  33. package/en/docusaurus-plugin-content-docs/current/apis/app/hooks/shared.md +6 -0
  34. package/en/docusaurus-plugin-content-docs/current/apis/app/hooks/src/_category_.json +4 -0
  35. package/en/docusaurus-plugin-content-docs/current/apis/app/hooks/src/app.md +45 -0
  36. package/en/docusaurus-plugin-content-docs/current/apis/app/hooks/src/index_.md +34 -0
  37. package/en/docusaurus-plugin-content-docs/current/apis/app/hooks/src/pages.md +180 -0
  38. package/en/docusaurus-plugin-content-docs/current/apis/app/hooks/src/stories.md +12 -0
  39. package/en/docusaurus-plugin-content-docs/current/apis/app/hooks/src/test.md +12 -0
  40. package/en/docusaurus-plugin-content-docs/current/apis/app/overview.md +12 -0
  41. package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/_category_.json +9 -0
  42. package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/app/_category_.json +4 -0
  43. package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/app/define-config.md +60 -0
  44. package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/bff/_category_.json +4 -0
  45. package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/bff/hook.md +43 -0
  46. package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/bff/use-context.md +36 -0
  47. package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/core/_category_.json +5 -0
  48. package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/core/bootstrap.md +55 -0
  49. package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/core/create-app.md +47 -0
  50. package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/core/use-loader.md +83 -0
  51. package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/core/use-module-apps.md +101 -0
  52. package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/core/use-runtime-context.md +59 -0
  53. package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/default-alias.md +25 -0
  54. package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/env.md +72 -0
  55. package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/index.md +12 -0
  56. package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/model/Provider.md +35 -0
  57. package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/model/_category_.json +4 -0
  58. package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/model/auto-actions.md +120 -0
  59. package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/model/connect.md +140 -0
  60. package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/model/create-app.md +73 -0
  61. package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/model/create-store.md +62 -0
  62. package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/model/handle-effect.md +105 -0
  63. package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/model/model_.md +197 -0
  64. package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/model/use-local-model.md +27 -0
  65. package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/model/use-model.md +89 -0
  66. package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/model/use-static-model.md +49 -0
  67. package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/model/use-store.md +48 -0
  68. package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/plugin/_category_.json +4 -0
  69. package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/plugin/abstract.md +26 -0
  70. package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/plugin/hook-api.md +896 -0
  71. package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/plugin/hook.md +170 -0
  72. package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/plugin/plugin-api.md +117 -0
  73. package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/router/_category_.json +4 -0
  74. package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/router/router.md +492 -0
  75. package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/ssr/_category_.json +4 -0
  76. package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/ssr/no-ssr.md +44 -0
  77. package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/ssr/pre-render.md +91 -0
  78. package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/testing/_category_.json +4 -0
  79. package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/testing/act.md +34 -0
  80. package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/testing/cleanup.md +38 -0
  81. package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/testing/render.md +72 -0
  82. package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/testing/renderApp.md +33 -0
  83. package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/utility/_category_.json +4 -0
  84. package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/utility/css-in-js.md +42 -0
  85. package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/utility/head.md +39 -0
  86. package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/utility/loadable.md +85 -0
  87. package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/web-server/_category_.json +4 -0
  88. package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/web-server/hook.md +131 -0
  89. package/en/docusaurus-plugin-content-docs/current/apis/app/runtime/web-server/middleware.md +106 -0
  90. package/en/docusaurus-plugin-content-docs/current/configure/app/bff/fetcher.md +28 -0
  91. package/en/docusaurus-plugin-content-docs/current/configure/app/bff/prefix.md +33 -0
  92. package/en/docusaurus-plugin-content-docs/current/configure/app/bff/proxy.md +75 -0
  93. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/dev/asset-prefix.md +0 -1
  94. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/dev/hmr.md +0 -1
  95. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/dev/https.md +0 -1
  96. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/dev/port.md +0 -1
  97. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/dev/progress-bar.md +0 -1
  98. package/en/docusaurus-plugin-content-docs/current/configure/app/dev/proxy.md +80 -0
  99. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/dev/start-url.md +0 -1
  100. package/en/docusaurus-plugin-content-docs/current/configure/app/dev/with-master-app.md +32 -0
  101. package/en/docusaurus-plugin-content-docs/current/configure/app/experiments/lazy-compilation.md +12 -0
  102. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/html/app-icon.md +0 -1
  103. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/html/crossorigin.md +0 -1
  104. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/html/disable-html-folder.md +0 -1
  105. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/html/favicon-by-entries.md +0 -1
  106. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/html/favicon.md +0 -1
  107. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/html/inject-by-entries.md +0 -1
  108. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/html/inject.md +0 -1
  109. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/html/meta-by-entries.md +0 -1
  110. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/html/meta.md +0 -1
  111. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/html/mount-id.md +0 -1
  112. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/html/template-by-entries.md +0 -1
  113. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/html/template-parameters-by-entries.md +0 -1
  114. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/html/template-parameters.md +0 -1
  115. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/html/template.md +0 -1
  116. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/html/title-by-entries.md +0 -1
  117. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/html/title.md +0 -1
  118. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/output/asset-prefix.md +0 -1
  119. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/output/assets-retry.md +0 -1
  120. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/output/charset.md +0 -1
  121. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/output/clean-dist-path.md +0 -1
  122. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/output/convert-to-rem.md +0 -1
  123. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/output/copy.md +0 -1
  124. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/output/css-module-local-ident-name.md +0 -1
  125. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/output/data-uri-limit.md +0 -1
  126. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/output/disable-css-module-extension.md +0 -1
  127. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/output/disable-filename-hash.md +0 -1
  128. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/output/disable-inline-runtime-chunk.md +0 -1
  129. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/output/disable-minimize.md +0 -1
  130. package/en/docusaurus-plugin-content-docs/current/configure/app/output/disable-node-polyfill.md +20 -0
  131. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/output/disable-source-map.md +0 -1
  132. package/en/docusaurus-plugin-content-docs/current/configure/app/output/disable-ts-checker.md +12 -0
  133. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/output/dist-path.md +0 -1
  134. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/output/enable-asset-fallback.md +0 -1
  135. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/output/enable-asset-manifest.md +0 -1
  136. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/output/enable-css-module-tsdeclaration.md +0 -1
  137. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/output/enable-inline-scripts.md +0 -1
  138. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/output/enable-inline-styles.md +0 -1
  139. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/output/enable-latest-decorators.md +0 -1
  140. package/en/docusaurus-plugin-content-docs/current/configure/app/output/enable-modern-mode.md +34 -0
  141. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/output/externals.md +0 -1
  142. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/output/filename.md +0 -1
  143. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/output/legal-comments.md +0 -1
  144. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/output/override-browserslist.md +0 -1
  145. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/output/polyfill.md +0 -1
  146. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/output/svg-default-export.md +0 -1
  147. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/performance/build-cache.md +0 -1
  148. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/performance/bundle-analyze.md +0 -1
  149. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/performance/chunk-split.md +0 -1
  150. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/performance/print-file-size.md +0 -1
  151. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/performance/profile.md +0 -1
  152. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/performance/remove-console.md +0 -1
  153. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/performance/remove-moment-locale.md +0 -1
  154. package/en/docusaurus-plugin-content-docs/current/configure/app/plugins.md +74 -0
  155. package/en/docusaurus-plugin-content-docs/current/configure/app/runtime/intro.md +91 -0
  156. package/en/docusaurus-plugin-content-docs/current/configure/app/runtime/master-app.md +60 -0
  157. package/en/docusaurus-plugin-content-docs/current/configure/app/runtime/router.md +19 -0
  158. package/en/docusaurus-plugin-content-docs/current/configure/app/runtime/state.md +41 -0
  159. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/security/sri.md +0 -1
  160. package/en/docusaurus-plugin-content-docs/current/configure/app/server/base-url.md +33 -0
  161. package/en/docusaurus-plugin-content-docs/current/configure/app/server/port.md +18 -0
  162. package/en/docusaurus-plugin-content-docs/current/configure/app/server/public-routes.md +26 -0
  163. package/en/docusaurus-plugin-content-docs/current/configure/app/server/routes.md +91 -0
  164. package/en/docusaurus-plugin-content-docs/current/configure/app/server/ssr-by-entries.md +28 -0
  165. package/en/docusaurus-plugin-content-docs/current/configure/app/server/ssr.md +20 -0
  166. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/source/alias.md +0 -1
  167. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/source/compile-js-data-uri.md +0 -1
  168. package/en/docusaurus-plugin-content-docs/current/configure/app/source/config-dir.md +23 -0
  169. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/source/define.md +0 -1
  170. package/en/docusaurus-plugin-content-docs/current/configure/app/source/design-system.md +1150 -0
  171. package/en/docusaurus-plugin-content-docs/current/configure/app/source/disable-default-entries.md +28 -0
  172. package/en/docusaurus-plugin-content-docs/current/configure/app/source/enable-async-entry.md +50 -0
  173. package/en/docusaurus-plugin-content-docs/current/configure/app/source/entries-dir.md +38 -0
  174. package/en/docusaurus-plugin-content-docs/current/configure/app/source/entries.md +62 -0
  175. package/en/docusaurus-plugin-content-docs/current/configure/app/source/exclude.md +12 -0
  176. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/source/global-vars.md +0 -1
  177. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/source/include.md +0 -1
  178. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/source/module-scopes.md +0 -1
  179. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/source/pre-entry.md +0 -1
  180. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/source/resolve-extension-prefix.md +0 -1
  181. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/source/resolve-main-fields.md +0 -1
  182. package/en/docusaurus-plugin-content-docs/current/configure/app/testing/transformer.md +18 -0
  183. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/tools/autoprefixer.md +0 -1
  184. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/tools/babel.md +0 -1
  185. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/tools/css-extract.md +0 -1
  186. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/tools/css-loader.md +0 -1
  187. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/tools/dev-server.md +0 -1
  188. package/en/docusaurus-plugin-content-docs/current/configure/app/tools/esbuild.md +61 -0
  189. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/tools/html-plugin.md +0 -1
  190. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/tools/inspector.md +0 -1
  191. package/en/docusaurus-plugin-content-docs/current/configure/app/tools/jest.md +39 -0
  192. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/tools/less.md +0 -1
  193. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/tools/minify-css.md +0 -1
  194. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/tools/postcss.md +0 -1
  195. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/tools/pug.md +0 -1
  196. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/tools/sass.md +0 -1
  197. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/tools/style-loader.md +0 -1
  198. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/tools/styled-components.md +0 -1
  199. package/en/docusaurus-plugin-content-docs/current/configure/app/tools/tailwindcss.md +47 -0
  200. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/tools/terser.md +0 -1
  201. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/tools/ts-checker.md +0 -1
  202. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/tools/ts-loader.md +0 -1
  203. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/tools/webpack-chain.md +0 -1
  204. package/en/{configure → docusaurus-plugin-content-docs/current/configure}/app/tools/webpack.md +0 -1
  205. package/en/docusaurus-plugin-content-docs/current/configure/app/usage.md +92 -0
  206. package/en/{tutorials → docusaurus-plugin-content-docs/current/tutorials}/foundations/_category_.json +0 -0
  207. package/en/{tutorials → docusaurus-plugin-content-docs/current/tutorials}/foundations/basic.md +0 -0
  208. package/en/{tutorials → docusaurus-plugin-content-docs/current/tutorials}/foundations/introduction.md +0 -0
  209. package/en/docusaurus-plugin-content-docs/current.json +262 -0
  210. package/package.json +7 -5
  211. package/scripts/config.ts +98 -0
  212. package/scripts/summary.en.json +1 -0
  213. package/scripts/summary.zh.json +1 -0
  214. package/scripts/sync.ts +26 -5
  215. package/zh/apis/app/commands/build.md +2 -2
  216. package/zh/apis/app/commands/dev.md +1 -1
  217. package/zh/apis/app/commands/index.md +1 -1
  218. package/zh/apis/app/commands/lint.md +2 -2
  219. package/zh/apis/app/commands/new.md +1 -1
  220. package/zh/apis/app/commands/start.md +1 -1
  221. package/zh/apis/app/commands/test.md +1 -1
  222. package/zh/apis/app/commands/upgrade.md +0 -2
  223. package/zh/apis/app/hooks/api/framework/_category_.json +1 -1
  224. package/zh/apis/app/hooks/api/framework/lambda.md +8 -33
  225. package/zh/apis/app/hooks/api/functions/_category_.json +1 -1
  226. package/zh/apis/app/hooks/api/functions/api.md +29 -2
  227. package/zh/apis/app/hooks/api/functions/app.md +5 -3
  228. package/zh/apis/app/hooks/api/functions/common.md +3 -5
  229. package/zh/apis/app/hooks/api/test.md +2 -4
  230. package/zh/apis/app/hooks/config/html.md +1 -3
  231. package/zh/apis/app/hooks/config/icon.md +2 -2
  232. package/zh/apis/app/hooks/config/mock.md +2 -8
  233. package/zh/apis/app/hooks/config/public.md +2 -4
  234. package/zh/apis/app/hooks/config/storybook.md +2 -4
  235. package/zh/apis/app/hooks/config/upload.md +1 -7
  236. package/zh/apis/app/hooks/modern-config.md +1 -3
  237. package/zh/apis/app/hooks/server/index_.md +12 -0
  238. package/zh/apis/app/hooks/server/test.md +3 -3
  239. package/zh/apis/app/hooks/shared.md +1 -2
  240. package/zh/apis/app/hooks/src/app.md +8 -4
  241. package/zh/apis/app/hooks/src/{index.md → index_.md} +2 -2
  242. package/zh/apis/app/hooks/src/pages.md +3 -4
  243. package/zh/apis/app/hooks/src/stories.md +2 -2
  244. package/zh/apis/app/hooks/src/test.md +1 -1
  245. package/zh/apis/app/overview.md +1 -1
  246. package/zh/apis/app/runtime/app/_category_.json +2 -2
  247. package/zh/apis/app/runtime/app/define-config.md +14 -10
  248. package/zh/apis/app/runtime/bff/_category_.json +4 -0
  249. package/zh/apis/app/runtime/bff/hook.md +43 -0
  250. package/zh/apis/app/runtime/bff/use-context.md +36 -0
  251. package/zh/apis/app/runtime/core/_category_.json +4 -0
  252. package/zh/apis/app/runtime/core/bootstrap.md +55 -0
  253. package/zh/apis/app/runtime/core/create-app.md +47 -0
  254. package/zh/apis/app/runtime/core/use-loader.md +83 -0
  255. package/zh/apis/app/runtime/core/use-module-apps.md +101 -0
  256. package/zh/apis/app/runtime/core/use-runtime-context.md +59 -0
  257. package/zh/apis/app/runtime/default-alias.md +4 -7
  258. package/zh/apis/app/runtime/env.md +22 -20
  259. package/zh/apis/app/runtime/model/Provider.md +6 -8
  260. package/zh/apis/app/runtime/model/_category_.json +1 -1
  261. package/zh/apis/app/runtime/model/auto-actions.md +1 -2
  262. package/zh/apis/app/runtime/model/connect.md +8 -5
  263. package/zh/apis/app/runtime/model/create-app.md +3 -4
  264. package/zh/apis/app/runtime/model/create-store.md +5 -3
  265. package/zh/apis/app/runtime/model/handle-effect.md +5 -5
  266. package/zh/apis/app/runtime/model/model_.md +3 -3
  267. package/zh/apis/app/runtime/model/use-local-model.md +2 -2
  268. package/zh/apis/app/runtime/model/use-model.md +6 -7
  269. package/zh/apis/app/runtime/model/use-static-model.md +2 -2
  270. package/zh/apis/app/runtime/model/use-store.md +3 -3
  271. package/zh/apis/app/runtime/router/_category_.json +4 -0
  272. package/zh/apis/app/runtime/{container → router}/router.md +0 -0
  273. package/zh/apis/app/runtime/ssr/_category_.json +4 -0
  274. package/zh/apis/app/runtime/ssr/no-ssr.md +41 -0
  275. package/zh/apis/app/runtime/ssr/pre-render.md +91 -0
  276. package/zh/apis/app/runtime/testing/_category_.json +1 -1
  277. package/zh/apis/app/runtime/testing/act.md +8 -8
  278. package/zh/apis/app/runtime/testing/cleanup.md +10 -9
  279. package/zh/apis/app/runtime/testing/render.md +43 -23
  280. package/zh/apis/app/runtime/testing/renderApp.md +8 -8
  281. package/zh/apis/app/runtime/utility/_category_.json +1 -1
  282. package/zh/apis/app/runtime/utility/css-in-js.md +17 -35
  283. package/zh/apis/app/runtime/{app → utility}/head.md +6 -10
  284. package/zh/apis/app/runtime/utility/{loadable/loadable_.md → loadable.md} +29 -56
  285. package/zh/apis/app/runtime/web-server/_category_.json +1 -1
  286. package/zh/apis/app/runtime/web-server/hook.md +100 -90
  287. package/zh/apis/app/runtime/web-server/middleware.md +106 -0
  288. package/zh/apis/monorepo/commands/bump.md +1 -1
  289. package/zh/apis/monorepo/commands/change.md +1 -1
  290. package/zh/apis/monorepo/commands/clear.md +1 -1
  291. package/zh/apis/monorepo/commands/deploy.md +1 -1
  292. package/zh/apis/monorepo/commands/gen-release-note.md +1 -1
  293. package/zh/apis/monorepo/commands/lint.md +1 -1
  294. package/zh/apis/monorepo/commands/new.md +1 -1
  295. package/zh/apis/monorepo/commands/pre.md +1 -1
  296. package/zh/apis/monorepo/commands/release.md +1 -1
  297. package/zh/configure/app/bff/fetcher.md +1 -2
  298. package/zh/configure/app/bff/prefix.md +2 -3
  299. package/zh/configure/app/bff/proxy.md +8 -13
  300. package/zh/configure/app/dev/asset-prefix.md +0 -1
  301. package/zh/configure/app/dev/hmr.md +0 -1
  302. package/zh/configure/app/dev/https.md +0 -1
  303. package/zh/configure/app/dev/port.md +0 -1
  304. package/zh/configure/app/dev/progress-bar.md +0 -1
  305. package/zh/configure/app/dev/proxy.md +2 -3
  306. package/zh/configure/app/dev/start-url.md +0 -1
  307. package/zh/configure/app/dev/with-master-app.md +0 -1
  308. package/zh/configure/app/experiments/lazy-compilation.md +12 -0
  309. package/zh/configure/app/html/app-icon.md +0 -1
  310. package/zh/configure/app/html/crossorigin.md +0 -1
  311. package/zh/configure/app/html/disable-html-folder.md +0 -1
  312. package/zh/configure/app/html/favicon-by-entries.md +0 -1
  313. package/zh/configure/app/html/favicon.md +0 -1
  314. package/zh/configure/app/html/inject-by-entries.md +0 -1
  315. package/zh/configure/app/html/inject.md +0 -1
  316. package/zh/configure/app/html/meta-by-entries.md +0 -1
  317. package/zh/configure/app/html/meta.md +0 -1
  318. package/zh/configure/app/html/mount-id.md +0 -1
  319. package/zh/configure/app/html/template-by-entries.md +0 -1
  320. package/zh/configure/app/html/template-parameters-by-entries.md +0 -1
  321. package/zh/configure/app/html/template-parameters.md +0 -1
  322. package/zh/configure/app/html/template.md +0 -1
  323. package/zh/configure/app/html/title-by-entries.md +0 -1
  324. package/zh/configure/app/html/title.md +0 -1
  325. package/zh/configure/app/output/asset-prefix.md +0 -1
  326. package/zh/configure/app/output/assets-retry.md +0 -1
  327. package/zh/configure/app/output/charset.md +0 -1
  328. package/zh/configure/app/output/clean-dist-path.md +0 -1
  329. package/zh/configure/app/output/convert-to-rem.md +0 -1
  330. package/zh/configure/app/output/copy.md +0 -1
  331. package/zh/configure/app/output/css-module-local-ident-name.md +0 -1
  332. package/zh/configure/app/output/data-uri-limit.md +0 -1
  333. package/zh/configure/app/output/disable-css-module-extension.md +0 -1
  334. package/zh/configure/app/output/disable-filename-hash.md +0 -1
  335. package/zh/configure/app/output/disable-inline-runtime-chunk.md +0 -1
  336. package/zh/configure/app/output/disable-minimize.md +0 -1
  337. package/zh/configure/app/output/disable-node-polyfill.md +2 -4
  338. package/zh/configure/app/output/disable-source-map.md +0 -1
  339. package/zh/configure/app/output/disable-ts-checker.md +12 -0
  340. package/zh/configure/app/output/dist-path.md +0 -1
  341. package/zh/configure/app/output/enable-asset-fallback.md +0 -1
  342. package/zh/configure/app/output/enable-asset-manifest.md +0 -1
  343. package/zh/configure/app/output/enable-css-module-tsdeclaration.md +0 -1
  344. package/zh/configure/app/output/enable-inline-scripts.md +0 -1
  345. package/zh/configure/app/output/enable-inline-styles.md +0 -1
  346. package/zh/configure/app/output/enable-latest-decorators.md +0 -1
  347. package/zh/configure/app/output/enable-modern-mode.md +13 -5
  348. package/zh/configure/app/output/externals.md +0 -1
  349. package/zh/configure/app/output/filename.md +0 -1
  350. package/zh/configure/app/output/legal-comments.md +0 -1
  351. package/zh/configure/app/output/override-browserslist.md +0 -1
  352. package/zh/configure/app/output/polyfill.md +0 -1
  353. package/zh/configure/app/output/svg-default-export.md +0 -1
  354. package/zh/configure/app/performance/build-cache.md +0 -1
  355. package/zh/configure/app/performance/bundle-analyze.md +0 -1
  356. package/zh/configure/app/performance/chunk-split.md +0 -1
  357. package/zh/configure/app/performance/print-file-size.md +0 -1
  358. package/zh/configure/app/performance/profile.md +0 -1
  359. package/zh/configure/app/performance/remove-console.md +0 -1
  360. package/zh/configure/app/performance/remove-moment-locale.md +0 -1
  361. package/zh/configure/app/runtime/intro.md +92 -0
  362. package/zh/configure/app/runtime/master-app.md +8 -21
  363. package/zh/configure/app/runtime/router.md +4 -38
  364. package/zh/configure/app/runtime/state.md +10 -13
  365. package/zh/configure/app/security/sri.md +0 -1
  366. package/zh/configure/app/server/base-url.md +1 -2
  367. package/zh/configure/app/server/port.md +1 -2
  368. package/zh/configure/app/server/public-routes.md +1 -2
  369. package/zh/configure/app/server/routes.md +4 -5
  370. package/zh/configure/app/server/ssr-by-entries.md +2 -3
  371. package/zh/configure/app/server/ssr.md +1 -2
  372. package/zh/configure/app/source/alias.md +0 -1
  373. package/zh/configure/app/source/compile-js-data-uri.md +0 -1
  374. package/zh/configure/app/source/config-dir.md +12 -4
  375. package/zh/configure/app/source/define.md +0 -1
  376. package/zh/configure/app/source/design-system.md +14 -24
  377. package/zh/configure/app/source/disable-default-entries.md +8 -3
  378. package/zh/configure/app/source/enable-async-entry.md +3 -3
  379. package/zh/configure/app/source/entries-dir.md +1 -1
  380. package/zh/configure/app/source/entries.md +16 -9
  381. package/zh/configure/app/source/exclude.md +12 -0
  382. package/zh/configure/app/source/global-vars.md +0 -1
  383. package/zh/configure/app/source/include.md +0 -1
  384. package/zh/configure/app/source/module-scopes.md +0 -1
  385. package/zh/configure/app/source/pre-entry.md +0 -1
  386. package/zh/configure/app/source/resolve-extension-prefix.md +0 -1
  387. package/zh/configure/app/source/resolve-main-fields.md +0 -1
  388. package/zh/configure/app/testing/transformer.md +2 -4
  389. package/zh/configure/app/tools/autoprefixer.md +0 -1
  390. package/zh/configure/app/tools/babel.md +0 -1
  391. package/zh/configure/app/tools/css-extract.md +0 -1
  392. package/zh/configure/app/tools/css-loader.md +0 -1
  393. package/zh/configure/app/tools/dev-server.md +0 -1
  394. package/zh/configure/app/tools/esbuild.md +5 -5
  395. package/zh/configure/app/tools/html-plugin.md +0 -1
  396. package/zh/configure/app/tools/inspector.md +0 -1
  397. package/zh/configure/app/tools/jest.md +2 -4
  398. package/zh/configure/app/tools/less.md +0 -1
  399. package/zh/configure/app/tools/minify-css.md +0 -1
  400. package/zh/configure/app/tools/postcss.md +0 -1
  401. package/zh/configure/app/tools/pug.md +0 -1
  402. package/zh/configure/app/tools/sass.md +0 -1
  403. package/zh/configure/app/tools/style-loader.md +0 -1
  404. package/zh/configure/app/tools/styled-components.md +0 -1
  405. package/zh/configure/app/tools/terser.md +0 -1
  406. package/zh/configure/app/tools/ts-checker.md +0 -1
  407. package/zh/configure/app/tools/ts-loader.md +0 -1
  408. package/zh/configure/app/tools/webpack-chain.md +0 -1
  409. package/zh/configure/app/tools/webpack.md +0 -1
  410. package/zh/configure/app/usage.md +15 -4
  411. package/zh/guides/advanced-features/bff/bff-server.md +1 -1
  412. package/zh/guides/advanced-features/bff/frameworks.md +0 -221
  413. package/zh/guides/advanced-features/code-split.md +1 -1
  414. package/zh/guides/advanced-features/low-level.md +2 -2
  415. package/zh/guides/advanced-features/ssg.md +2 -2
  416. package/zh/guides/advanced-features/ssr.md +4 -4
  417. package/zh/guides/basic-features/alias.md +1 -1
  418. package/zh/guides/basic-features/css/postcss.md +1 -1
  419. package/zh/guides/basic-features/css/tailwindcss.md +2 -2
  420. package/zh/guides/basic-features/env-vars.md +2 -3
  421. package/zh/guides/basic-features/proxy.md +2 -2
  422. package/zh/guides/topic-detail/compile-speed.md +5 -5
  423. package/zh/guides/topic-detail/generator/_category_.json +4 -0
  424. package/zh/guides/topic-detail/generator/codesmith/_category_.json +4 -0
  425. package/zh/guides/topic-detail/generator/codesmith/introduce.md +5 -0
  426. package/zh/guides/topic-detail/generator/config/_category_.json +4 -0
  427. package/zh/{configure/generator/introduce.md → guides/topic-detail/generator/config/common.md} +35 -42
  428. package/zh/{configure/generator → guides/topic-detail/generator/config}/module.md +7 -11
  429. package/zh/{configure/generator → guides/topic-detail/generator/config}/monorepo.md +4 -4
  430. package/zh/{configure/generator → guides/topic-detail/generator/config}/mwa.md +11 -45
  431. package/zh/guides/topic-detail/generator/plugin/_category_.json +4 -0
  432. package/zh/guides/topic-detail/{generator-plugin → generator/plugin}/abstract.md +0 -0
  433. package/zh/guides/topic-detail/generator/plugin/api/_category_.json +4 -0
  434. package/zh/{apis/generator/plugin → guides/topic-detail/generator/plugin/api}/file/_category_.json +0 -0
  435. package/zh/{apis/generator/plugin → guides/topic-detail/generator/plugin/api}/file/addFile.md +1 -1
  436. package/zh/{apis/generator/plugin → guides/topic-detail/generator/plugin/api}/file/addHelper.md +0 -0
  437. package/zh/{apis/generator/plugin → guides/topic-detail/generator/plugin/api}/file/addManyFile.md +1 -1
  438. package/zh/{apis/generator/plugin → guides/topic-detail/generator/plugin/api}/file/addPartial.md +0 -0
  439. package/zh/{apis/generator/plugin → guides/topic-detail/generator/plugin/api}/file/introduce.md +0 -0
  440. package/zh/{apis/generator/plugin → guides/topic-detail/generator/plugin/api}/file/rmDir.md +0 -0
  441. package/zh/{apis/generator/plugin → guides/topic-detail/generator/plugin/api}/file/rmFile.md +0 -0
  442. package/zh/{apis/generator/plugin → guides/topic-detail/generator/plugin/api}/file/updateJSONFile.md +0 -0
  443. package/zh/{apis/generator/plugin → guides/topic-detail/generator/plugin/api}/file/updateModernConfig.md +0 -0
  444. package/zh/{apis/generator/plugin → guides/topic-detail/generator/plugin/api}/file/updateTextRawFile.md +0 -0
  445. package/zh/{apis/generator/plugin → guides/topic-detail/generator/plugin/api}/git/_category_.json +0 -0
  446. package/zh/{apis/generator/plugin → guides/topic-detail/generator/plugin/api}/git/gitAddAndCommit.md +0 -0
  447. package/zh/{apis/generator/plugin → guides/topic-detail/generator/plugin/api}/git/initGitRepo.md +0 -0
  448. package/zh/{apis/generator/plugin → guides/topic-detail/generator/plugin/api}/git/isInGitRepo.md +0 -0
  449. package/zh/{apis/generator/plugin → guides/topic-detail/generator/plugin/api}/hook/_category_.json +0 -0
  450. package/zh/{apis/generator/plugin → guides/topic-detail/generator/plugin/api}/hook/afterForged.md +1 -1
  451. package/zh/{apis/generator/plugin → guides/topic-detail/generator/plugin/api}/hook/onForged.md +1 -1
  452. package/zh/{apis/generator/plugin → guides/topic-detail/generator/plugin/api}/info/_category_.json +0 -0
  453. package/zh/{apis/generator/plugin → guides/topic-detail/generator/plugin/api}/info/isFileExit.md +0 -0
  454. package/zh/{apis/generator/plugin → guides/topic-detail/generator/plugin/api}/info/locale.md +0 -0
  455. package/zh/{apis/generator/plugin → guides/topic-detail/generator/plugin/api}/info/readDir.md +0 -0
  456. package/zh/{apis/generator/plugin → guides/topic-detail/generator/plugin/api}/input/_category_.json +0 -0
  457. package/zh/{apis/generator/plugin → guides/topic-detail/generator/plugin/api}/input/addInputAfter.md +14 -6
  458. package/zh/{apis/generator/plugin → guides/topic-detail/generator/plugin/api}/input/addInputBefore.md +14 -6
  459. package/zh/{apis/generator/plugin → guides/topic-detail/generator/plugin/api}/input/setInput.md +2 -2
  460. package/zh/{apis/generator/plugin → guides/topic-detail/generator/plugin/api}/input/setInputValue.md +0 -0
  461. package/zh/guides/topic-detail/generator/plugin/api/input/type.md +65 -0
  462. package/zh/{apis/generator/plugin → guides/topic-detail/generator/plugin/api}/introduce.md +0 -0
  463. package/zh/{apis/generator/plugin → guides/topic-detail/generator/plugin/api}/new/_category_.json +0 -0
  464. package/zh/{apis/generator/plugin → guides/topic-detail/generator/plugin/api}/new/createElement.md +1 -1
  465. package/zh/{apis/generator/plugin → guides/topic-detail/generator/plugin/api}/new/createSubProject.md +1 -1
  466. package/zh/{apis/generator/plugin → guides/topic-detail/generator/plugin/api}/new/enableFunc.md +1 -3
  467. package/zh/{apis/generator/plugin → guides/topic-detail/generator/plugin/api}/new/introduce.md +3 -3
  468. package/zh/{apis/generator/plugin → guides/topic-detail/generator/plugin/api}/npm/_category_.json +0 -0
  469. package/zh/{apis/generator/plugin → guides/topic-detail/generator/plugin/api}/npm/install.md +0 -0
  470. package/zh/guides/topic-detail/{generator-plugin → generator/plugin}/develop.md +4 -4
  471. package/zh/guides/topic-detail/{generator-plugin → generator/plugin}/use.md +0 -0
  472. package/zh/guides/topic-detail/generator/project.md +117 -0
  473. package/zh/guides/topic-detail/micro-frontend/debugging.md +5 -5
  474. package/zh/guides/topic-detail/micro-frontend/route-mode.md +2 -2
  475. package/zh/guides/troubleshooting/compile.md +3 -3
  476. package/zh/tutorials/first-app/c01-getting-started/1.4-enable-ssr.md +2 -2
  477. package/zh/tutorials/first-app/c04-es6-plus-and-ts/4.3-compatibility.md +4 -4
  478. package/zh/tutorials/first-app/c06-css-and-component/6.4-design-system.md +3 -3
  479. package/zh/tutorials/first-app/c07-app-entry/7.3-manage-entries-by-hand.md +2 -2
  480. package/zh/tutorials/first-app/c08-client-side-routing/8.1-code-based-routing.md +1 -1
  481. package/scripts/gen-config.ts +0 -60
  482. package/zh/apis/app/hooks/api/framework/app.md +0 -100
  483. package/zh/apis/app/hooks/server/index.md +0 -14
  484. package/zh/apis/app/hooks/src/error.md +0 -10
  485. package/zh/apis/app/hooks/src/eslint.md +0 -9
  486. package/zh/apis/app/runtime/app/bootstrap.md +0 -83
  487. package/zh/apis/app/runtime/app/create-app.md +0 -47
  488. package/zh/apis/app/runtime/app/no-ssr.md +0 -41
  489. package/zh/apis/app/runtime/app/pre-render.md +0 -77
  490. package/zh/apis/app/runtime/app/use-module-app.md +0 -60
  491. package/zh/apis/app/runtime/app/use-module-apps.md +0 -64
  492. package/zh/apis/app/runtime/app/use-runtime-context.md +0 -39
  493. package/zh/apis/app/runtime/bff-server/_category_.json +0 -4
  494. package/zh/apis/app/runtime/bff-server/after-lambda-registed.md +0 -35
  495. package/zh/apis/app/runtime/bff-server/hook.md +0 -120
  496. package/zh/apis/app/runtime/bff-server/use-context.md +0 -70
  497. package/zh/apis/app/runtime/container/_category_.json +0 -4
  498. package/zh/apis/app/runtime/container/use-loader.md +0 -64
  499. package/zh/apis/app/runtime/utility/loadable/_category_.json +0 -4
  500. package/zh/apis/app/runtime/utility/loadable/lazy.md +0 -29
  501. package/zh/apis/app/runtime/utility/loadable/loadable-component.md +0 -61
  502. package/zh/apis/app/runtime/utility/loadable/loadable-library.md +0 -67
  503. package/zh/apis/generator/plugin/_category_.json +0 -4
  504. package/zh/apis/generator/plugin/input/addOptionAfter.md +0 -45
  505. package/zh/apis/generator/plugin/input/addOptionBefore.md +0 -45
  506. package/zh/apis/generator/plugin/input/type.md +0 -101
  507. package/zh/guides/topic-detail/generator-plugin/_category_.json +0 -4
@@ -0,0 +1,47 @@
1
+ ---
2
+ title: createApp
3
+ ---
4
+
5
+ 用于创建自定义入口,定制运行时插件。只有在使用[自定义入口](/docs/guides/advanced-features/custom-app)时,才需要使用该 API。
6
+
7
+ ## 使用姿势
8
+
9
+ ```ts
10
+ import { createApp } from '@modern-js/runtime';
11
+ ```
12
+
13
+ ## 函数签名
14
+
15
+ ```ts
16
+ import type { Plugin } from '@modern-js/runtime';
17
+
18
+ function createApp(options: { plugins: Plugin[] }): React.ComponentType<any>;
19
+ ```
20
+
21
+ ### 参数
22
+
23
+ - `options`: 可选的参数。
24
+ - `plugins`:自定义的插件扩展。
25
+
26
+ ## 示例
27
+
28
+ ### 创建自定义入口
29
+
30
+ 详见 [`bootstrap`](./bootstrap.md)。
31
+
32
+ ### 定制插件
33
+
34
+ ```ts
35
+ import { createApp } from '@modern-js/runtime';
36
+
37
+ function App() {
38
+ return <div>app</div>;
39
+ }
40
+
41
+ export default createApp({
42
+ plugins: [
43
+ router({}),
44
+ state({}),
45
+ ]
46
+ })(App);
47
+ ```
@@ -0,0 +1,83 @@
1
+ ---
2
+ title: useLoader
3
+ ---
4
+
5
+ 一个同构的 API,通常会用来做异步请求。当 SSR 的时候,服务端使用 `useLoader` 预加载数据,同时浏览器端也会复用这部分数据。
6
+
7
+ ## 使用姿势
8
+
9
+ ```ts
10
+ import { useLoader } from '@modern-js/runtime';
11
+ ```
12
+
13
+ ## 函数签名
14
+
15
+ ```ts
16
+ type LoaderFn = (context: runtimeContext) => Promise<unknow>;
17
+ type Options = {
18
+ onSuccess: (data: Record<string, any>) => void;
19
+ onError: (error: Error) => void;
20
+ initialData: Record<string, any>;
21
+ skip: boolean;
22
+ params: Record<string, any>;
23
+ static: boolean;
24
+ }
25
+ type ReturnData = {
26
+ data: Record<string, any>;
27
+ loading: boolean;
28
+ error: Error;
29
+ reload: (params?: Record<string, any>) => Promise<any> | undefined;
30
+ reloading: boolean;
31
+ }
32
+
33
+ function useLoader(loaderFn: LoaderFn, options: Options): ReturnData;
34
+ ```
35
+
36
+ :::info
37
+ `runtimeContext` 类型可以参考 [useRuntimeContext](/docs/apis/app/runtime/core/use-runtime-context)。
38
+ :::
39
+
40
+ ### 参数
41
+
42
+ - `loaderFn`:用于加载数据的函数,返回 Promise。
43
+ - `options`:可选配置项。
44
+ - `onSuccess`:执行成功的回调。
45
+ - `onError`:执行失败的回调。
46
+ - `initialData`:首次执行前的初始数据,对应返回值中的 `data` 字段。
47
+ - `skip`:当值为 `true` 时,函数不执行。
48
+ - `params`:当 `params` 序列化结果发生改变时,函数会重新执行。同时,`params` 也会作为函数的第二个参数被传入。
49
+ - `static`:当值为 `true` 时,`useLoader` 用于 [SSG](/docs/guides/advanced-features/ssg) 编译阶段数据的获取。
50
+
51
+ ### 返回值
52
+
53
+ - `data`:执行成功时的返回数据。
54
+ - `loading`:表示函数是否处于执行过程中。
55
+ - `error`:函数执行失败时的错误信息。
56
+ - `reload`:调用后可以重新执行函数。
57
+ - `params`:当值为 `undefined` 时,函数执行时将复用上次的值;否则会使用新的值重新执行函数。
58
+ - `reloading`:调用 `reload` 的执行过程中,`reloading` 值为 `true`。
59
+
60
+ ## 示例
61
+
62
+ ```ts
63
+ function Container() {
64
+ const { data, error, loading } = useLoader(
65
+ async (context, params) => {
66
+ console.log(params) // nicole
67
+ return fetch(user);
68
+ },
69
+ {
70
+ onSuccess: data => {
71
+ console.log('I did success:(', data);
72
+ },
73
+ onError: error => {
74
+ console.log('I met error:)', error);
75
+ },
76
+ initialData: { name: 'nicole', gender: 'female' },
77
+ params: 'nicole'
78
+ }
79
+ );
80
+
81
+ return ...;
82
+ }
83
+ ```
@@ -0,0 +1,101 @@
1
+ ---
2
+ title: useModuleApps
3
+ ---
4
+
5
+ 返回所有微前端子应用的 React 组件,用于可自由控制路由。
6
+
7
+ ## 使用姿势
8
+
9
+ ```tsx
10
+ import { useModuleApps } from '@modern/plugin-garfish';
11
+ ```
12
+
13
+ :::info 开启微前端
14
+ 该 API 在微前端主应用中使用,请先执行 `pnpm run new` 开启微前端功能。
15
+
16
+ ```bash
17
+ pnpm run new
18
+ ? 请选择你想要的操作 启用可选功能
19
+ ? 启用可选功能 启用「微前端」模式
20
+ ```
21
+ :::
22
+
23
+ ## 函数签名
24
+
25
+ `function useModuleApps(): Record<string, React.FC<any>>`
26
+
27
+ 分别返回包裹每个子应用后的 React 组件。
28
+
29
+ ## 示例
30
+
31
+ 需要先配置微前端子应用信息。
32
+
33
+ ```ts title=modern.config.js
34
+ module.exports = {
35
+ runtime: {
36
+ features:{
37
+ masterApp: {
38
+ apps: [
39
+ {
40
+ name: 'Home',
41
+ entry: 'http://www.home.com'
42
+ },
43
+ {
44
+ name: 'Contact',
45
+ entry: 'http://www.contact.com'
46
+ },
47
+ ]
48
+ }
49
+ }
50
+ }
51
+ }
52
+ ```
53
+
54
+ ```tsx title=App.tsx
55
+ function App() {
56
+ const { Components: { Home, Contact } } = useModuleApps();
57
+
58
+ return <div>
59
+ Master APP
60
+ <Route exact path='/home'>
61
+ <Home />
62
+ </Route>
63
+ <Route exact path='/home'>
64
+ <Contact />
65
+ </Route>
66
+ </div>;
67
+ }
68
+ ```
69
+
70
+ 通过 `useModuleApps()` 获取到 `Home` 和 `Contact` 子应用组件(名称和配置里的 `name` 字段对应),之后就可以像使用普通的 React 组件一样去加载子应用。
71
+
72
+
73
+ ## 加载动画
74
+
75
+ 可以通过以下方式,自定义组件加载过程的过渡动画。
76
+
77
+ ```tsx title=App.tsx
78
+ function App() {
79
+ const { Components: { Home } } = useModuleApps();
80
+
81
+ return <div>
82
+ Master APP
83
+ <Route exact path='/home'>
84
+ <Home
85
+ loadable={{
86
+ loading: ({ pastDelay, error }: any) => {
87
+ if (error) {
88
+ console.error(error);
89
+ return <div>error: {error?.message}</div>;
90
+ } else if (pastDelay) {
91
+ return <div>loading</div>;
92
+ } else {
93
+ return null;
94
+ }
95
+ },
96
+ }}
97
+ />
98
+ </Route>
99
+ </div>;
100
+ }
101
+ ```
@@ -0,0 +1,59 @@
1
+ ---
2
+ title: useRuntimeContext
3
+ ---
4
+
5
+ 该函数主要用于获取 Runtime 上下文,只能在函数组件中使用。
6
+
7
+ ## 使用姿势
8
+
9
+ ```tsx
10
+ import { useRuntimeContext } from '@modern-js/runtime';
11
+
12
+ export function App() {
13
+ const runtimeContext = useRuntimeContext();
14
+ return <div>Hello World</div>
15
+ }
16
+ ```
17
+
18
+ ## 函数签名
19
+
20
+ ```ts
21
+ type RuntimeContext = {
22
+ request: {
23
+ params: Record<string, string>;
24
+ pathname: string;
25
+ query: Record<string, string>;
26
+ headers: IncomingHttpHeaders;
27
+ cookie: string;
28
+ };
29
+ store: ReduckStore;
30
+ }
31
+
32
+ function useRuntimeContext(): RuntimeContext;
33
+ ```
34
+
35
+
36
+ ### 返回值
37
+
38
+ - `request`:请求上下文中的附加信息。
39
+ - `params`:请求路径中的动态参数。
40
+ - `pathname`:请求的 pathname。
41
+ - `query`:请求的查询字符串对象。
42
+ - `headers`:请求头信息。
43
+ - `cookie`:请求的 cookie 信息。
44
+ - `store`:在开启了 state 插件的时候,该值为 reduck 全局 `store`。
45
+
46
+ ## 示例
47
+
48
+ ```tsx
49
+ import { useRuntimeContext } from '@modern-js/runtime';
50
+ import { fooModel } from '@/common/models';
51
+
52
+ function App() {
53
+ const { store } = useRuntimeContext();
54
+
55
+ const [state, actions] = store.use(fooModel);
56
+
57
+ return <div>state: {state}</div>
58
+ }
59
+ ```
@@ -1,19 +1,16 @@
1
1
  ---
2
2
  sidebar_position: 1
3
+ title: 默认别名
3
4
  ---
4
- # 默认别名
5
-
6
-
7
- :::tip 提示
8
- - 除了以下默认别名,开发者可以在 `modern.config.js` 中自定义别名,详见[如何配置别名](/docs/configure/app/source/alias)。
9
- :::
10
-
11
5
 
12
6
  Modern.js 推荐通过别名的方式引用源码,其中包含 3 种默认别名:
13
7
  - `@/`:等价于引用项目根目录 `src/*` 下的文件。
14
8
  - `@api/`:等价于引用项目根目录下 `api/*` 下的文件(需要先开启 BFF 功能)。
15
9
  - `@shared/`:等价于引用项目根目录下 `shared/*` 下的文件。
16
10
 
11
+ :::tip 提示
12
+ - 除了以下默认别名,开发者可以在 `modern.config.js` 中自定义别名,详见[如何配置别名](/docs/configure/app/source/alias)。
13
+ :::
17
14
 
18
15
  ## 示例
19
16
  下面的例子展示了如何通过默认别名引用函数。
@@ -3,30 +3,42 @@ sidebar_position: 1
3
3
  title: 环境变量
4
4
  ---
5
5
 
6
+ Modern.js 内置了对环境变量的支持,包含内置的环境变量和自定义的环境变量。
6
7
 
7
- Modern.js 默认提供了下列环境变量:
8
+ ## 内置的环境变量
8
9
 
9
- - `NODE_ENV`:表示当前的执行环境。
10
- - `PORT`:表示应用运行的端口。
11
-
12
- ## NODE_ENV
10
+ ### NODE_ENV
13
11
 
14
12
  表示当前的执行环境,是**只读的**的环境变量,其值在不同的执行命令下具有不同的值:
15
13
 
16
- - `production`:执行 `modern build` 命令时的默认值。
14
+ - `production`:执行 `modern build`、`modern preview` 命令时的默认值。
17
15
  - `test`:执行 `modern test` 命令时的默认值。
18
16
  - `development`:执行 `modern dev` 命令时的默认值,同时也是其他所有情况下的默认值。
19
17
 
18
+ ### MODERN_ENV
19
+
20
+ 用于设置当前的执行环境,除了上述 NODE_ENV 对应的值之外,这里支持自定义环境名称,比如 `staging`、`boe` 等,Modern.js 会根据该环境变量对应的加载 env.{process.env.MODERN_ENV} 文件中设置的环境变量值。
21
+
22
+ 当需要通过环境名称使用不同的配置时,可以把环境变量定义到对应的环境名称的 env 文件中。
23
+
24
+ MODERN_ENV 的优先级高于 NODE_ENV。
25
+
20
26
  ## 自定义环境变量
21
27
 
22
- 除了上述默认提供的环境变量,还可以通过 `shell` 或 `.env` 文件自定义环境变量。
28
+ Modern.js 支持自定义的环境变量,以 `MODERN_` 开头的环境变量可以在代码中直接使用。
29
+
30
+ 如果需要自动以任意名称的环境变量,需要在 [`source.define`](/docs/configure/app/source/define) 配置中声明后使用。
31
+
32
+ ## 定义环境变量
33
+
34
+ 环境变量支持通过 `shell` 和 `.env` 文件两种方式指定。
23
35
 
24
36
  ### 通过 `shell` 指定
25
37
 
26
38
  在命令前添加自定义环境变量:
27
39
 
28
40
  ```shell
29
- FOO=123 BAR=456 pnpm run dev
41
+ REACT_APP_FOO=123 BAR=456 pnpm run dev
30
42
  ```
31
43
 
32
44
  ### 通过 `.env` 文件指定
@@ -34,21 +46,11 @@ FOO=123 BAR=456 pnpm run dev
34
46
  在项目根目录创建 `.env` 文件,其中添加自定义环境变量:
35
47
 
36
48
  ```env
37
- FOO=123
49
+ REACT_APP_FOO=123
38
50
  BAR=456
39
51
  ```
40
52
 
41
- 更多文件格式:
42
-
43
- - `.env`:默认文件。
44
- - `.env.development`:当 `NODE_ENV` 值为 `development` 时,读取该文件。
45
- - `.env.production`:当 `NODE_ENV` 值为 `production` 时,读取该文件。
46
- - `.env.test`:当 `NODE_ENV` 值为 `test` 时,读取该文件。
47
-
48
- ### 优先级
49
-
50
- - 当 `.env.*` 与 `.env` 同时存在,`.env.*` 会和 `.env` 进行合并,相同名称的环境变量以 `.env.*` 为准。
51
- - 通过 `.env` 设置的环境变量,优先级高于 `shell` 指定的环境变量。
53
+ .env 文件支持后缀名后 NODE_ENV 或 MODERN_ENV 定义的环境名称,如 `.env.development`,可根据项目需求进行定义。Modern.js 会根据环境名称变量值读取对应的 env 文件。
52
54
 
53
55
  ## 使用环境变量
54
56
 
@@ -3,13 +3,13 @@ sidebar_position: 8
3
3
  title: Provider
4
4
  ---
5
5
 
6
- import ReduckTip from '@site/docs/components/reduck-tip.md'
6
+ import ReduckTip from '@site-docs/components/reduck-tip.md'
7
7
 
8
8
  <ReduckTip />
9
9
 
10
10
  `Provider` 是一个组件,它将 Reduck 的 Store 注入到应用的组件树中,使组件树内部的组件可以访问 Model。一般情况下,`Provider` 会定义在组件树的最顶层。
11
11
 
12
- ## 类型
12
+ ## 函数签名
13
13
 
14
14
  ```ts
15
15
  interface ProviderProps {
@@ -18,15 +18,13 @@ interface ProviderProps {
18
18
  }
19
19
  ```
20
20
 
21
- ## 参数
21
+ ### 参数
22
22
 
23
- - store:可选。[`createStore`](./create-store.md) 创建的 Store 对象。
24
- - config:可选。创建 Reduck Store 的配置,同 [`createApp`](./create-app.md) 的 `config` 参数。
23
+ - store[`createStore`](./create-store.md) 创建的 Store 对象。
24
+ - config:创建 Reduck Store 的配置,同 [`createApp`](./create-app.md) 的 `config` 参数。
25
25
 
26
26
  ## 示例
27
- ```tsx
28
- // 应用入口文件
29
-
27
+ ```tsx title="应用入口文件"
30
28
  ReactDOM.render(
31
29
  <Provider>
32
30
  <App />
@@ -1,4 +1,4 @@
1
1
  {
2
2
  "label": "Model API",
3
- "position": 4
3
+ "position": 6
4
4
  }
@@ -3,8 +3,7 @@ sidebar_position: 6
3
3
  title: Auto actions
4
4
  ---
5
5
 
6
-
7
- import ReduckTip from '@site/docs/components/reduck-tip.md'
6
+ import ReduckTip from '@site-docs/components/reduck-tip.md'
8
7
 
9
8
  <ReduckTip />
10
9
 
@@ -3,7 +3,7 @@ sidebar_position: 5
3
3
  title: connect
4
4
  ---
5
5
 
6
- import ReduckTip from '@site/docs/components/reduck-tip.md'
6
+ import ReduckTip from '@site-docs/components/reduck-tip.md'
7
7
 
8
8
  <ReduckTip />
9
9
 
@@ -17,6 +17,9 @@ Reduck 原始类型较为复杂,以下涉及类型定义的地方,展示的
17
17
  ## 类型
18
18
 
19
19
  ```ts
20
+ type SelectStateToProps = (...modelStates: State[], ownProps? :any) => PlainObject;
21
+ type SelectActionsToProps = (...modelActions: Actions[], ownProps? :any) => PlainObject;
22
+
20
23
  function connect(models: Model, options?: ConnectOptions);
21
24
  function connect(
22
25
  models: [...Model[], SelectStateToProps?, SelectActionsToProps?],
@@ -26,11 +29,11 @@ function connect(
26
29
 
27
30
 
28
31
  ## 参数
29
- - models:传入的 1 个或 多个 Model,当 `models` 为数组类型参数时,最后两项元素可以是用于筛选 State 的函数( `SelectStateToProps` 类型)和用于筛选 Actions 的函数( `SelectActionsToProps` 类型)。
30
- - `SelectStateToProps` 类型为 `(...modelStates: State[], ownProps? :any) => PlainObject`, `modelStates` 是传入的 Model 对象的 State 组成的数组,`ownProps` 是当前组件接收外部传递的 `props`,`SelectStateToProps` 返回的数据会传递到组件的 `props` 上。当 `models` 中没有传入 `SelectStateToProps` 参数时,所有 Model 的 State 进行合并后传递到组件的 `props` 上。
31
- - `SelectActionsToProps` 类型为 `(...modelActions: Actions[], ownProps? :any) => PlainObject`, `modelActions` 是传入的 Model 对象的 Actions 组成的数组,`ownProps` 是当前组件接收外部传递的 `props`,`SelectActionsToProps` 返回的数据也会传递到组件的 `props` 上。当 `models` 中没有传入 `SelectActionsToProps` 参数时,所有 Model 的 Actions 进行合并后传递到组件的 `props` 上。
32
+ - `models`:传入的 1 个或多个 Model,当 `models` 为数组类型参数时,最后两项元素可以是用于筛选 State 的函数( `SelectStateToProps` 类型)和用于筛选 Actions 的函数( `SelectActionsToProps` 类型)。
33
+ - `SelectStateToProps`: `modelStates` 是传入的 Model 对象的 State 组成的数组,`ownProps` 是当前组件接收外部传递的 `props`,`SelectStateToProps` 返回的数据会传递到组件的 `props` 上。当 `models` 中没有传入 `SelectStateToProps` 参数时,所有 Model 的 State 进行合并后传递到组件的 `props` 上。
34
+ - `SelectActionsToProps`: `modelActions` 是传入的 Model 对象的 Actions 组成的数组,`ownProps` 是当前组件接收外部传递的 `props`,`SelectActionsToProps` 返回的数据也会传递到组件的 `props` 上。当 `models` 中没有传入 `SelectActionsToProps` 参数时,所有 Model 的 Actions 进行合并后传递到组件的 `props` 上。
32
35
 
33
- - options:可选参数,用于辅助配置。目前支持设置 `forwardRef`,用于控制是否转发组件的 `ref`,默认值为 `false`,表示不转发 `ref`。设置为 `{forwardRef: true}`,表示转发 `ref`。
36
+ - `options`:可选参数,用于辅助配置。目前支持设置 `forwardRef`,用于控制是否转发组件的 `ref`,默认值为 `false`,表示不转发 `ref`。设置为 `{forwardRef: true}`,表示转发 `ref`。
34
37
 
35
38
 
36
39
  ## 返回值
@@ -3,18 +3,17 @@ sidebar_position: 11
3
3
  title: createApp
4
4
  ---
5
5
 
6
- import ReduckTip from '@site/docs/components/reduck-tip.md'
6
+ import ReduckTip from '@site-docs/components/reduck-tip.md'
7
7
 
8
8
  <ReduckTip />
9
9
 
10
- 一个 Reduck 应用对应共享一个 Store 的应用。Reduck 内部默认会使用 `createApp` 创建一个全局应用,如果整个应用只需要共享一个 Store,那么是不需要使用 `createApp` 的。只有当需要在应用局部创建共享 Store 时,才需要使用 `createApp` 。
11
-
10
+ Reduck 内部默认会使用 `createApp` 创建一个全局应用,如果整个应用只需要共享一个 Store,那么是不需要使用 `createApp` 的。只有当需要在应用局部创建共享 Store 时,才需要使用 `createApp`。
12
11
 
13
12
  :::caution 注意
14
13
  - 注意 `@modern-js/runtime/model` 中导出的 `createApp` 用于管理状态,而 `@modern-js/runtime` 导出的 `createApp` 用于管理整个应用的运行时环境,两者功能不同。
15
14
  :::
16
15
 
17
- ## 类型
16
+ ## 函数签名
18
17
 
19
18
  ```ts
20
19
  interface AppConfig extends StoreConfig {
@@ -3,15 +3,17 @@ sidebar_position: 10
3
3
  title: createStore
4
4
  ---
5
5
 
6
- import ReduckTip from '@site/docs/components/reduck-tip.md'
6
+ import ReduckTip from '@site-docs/components/reduck-tip.md'
7
7
 
8
8
  <ReduckTip />
9
9
 
10
10
 
11
- `createStore` 用于创建一个 Store 对象。Reduck 的 Store 基于 Redux 的 [Store](https://redux.js.org/api/store) 实现,用于存储应用的状态,同时提供一组用于管理状态和 Model 的方法。一般情况下,不需要使用这个 API,只有需要完全掌控 Store 的创建时,才会使用这个 API。例如,自定义一个 Store,传入 [`Provider`](./Provider.md) 组件使用。
11
+ `createStore` 用于创建一个 Store 对象。Reduck 的 Store 基于 Redux 的 [Store](https://redux.js.org/api/store) 实现,用于存储应用的状态,同时提供一组用于管理状态和 Model 的方法。
12
12
 
13
+ 一般情况下,不需要使用这个 API,只有需要完全掌控 Store 的创建时,才会使用这个 API。例如,自定义一个 Store,传入 [`Provider`](./Provider.md) 组件使用。
13
14
 
14
- ## 类型
15
+
16
+ ## 函数签名
15
17
 
16
18
  ```ts
17
19
  interface StoreConfig {
@@ -3,11 +3,11 @@ sidebar_position: 7
3
3
  title: handleEffect
4
4
  ---
5
5
 
6
- import ReduckTip from '@site/docs/components/reduck-tip.md'
6
+ import ReduckTip from '@site-docs/components/reduck-tip.md'
7
7
 
8
8
  <ReduckTip />
9
9
 
10
- 一个异步函数类型的 Effect,通常有三种需要处理的状态: 1.请求中;2.请求成功;3.请求处理失败。这些状态处理的方式,就是编写对应的 Action 函数(pending、fulfilled、rejected)。
10
+ 一个异步函数类型的 Effect,通常有三种需要处理的状态: 请求中、请求成功、请求处理失败。这些状态处理的方式,就是编写对应的 Action 函数(pending、fulfilled、rejected)。
11
11
 
12
12
  借助 `handleEffect` API,我们可以生成默认的 Action 函数来处理异步请求各个阶段的不同结果。`handleEffect` 生成的 Action 返回的 State 的结构如下:
13
13
 
@@ -19,7 +19,7 @@ interface State {
19
19
  }
20
20
  ```
21
21
 
22
- ## 类型
22
+ ## 函数签名
23
23
 
24
24
  ```ts
25
25
  interface EffectActions {
@@ -40,7 +40,7 @@ interface Config {
40
40
  function handleEffect(config: Config): EffectActions;
41
41
  ```
42
42
 
43
- ## 参数
43
+ ### 参数
44
44
 
45
45
  - ns:默认返回的 State 结构扁平地挂载到 Model 的 State 上,通过设置该参数可以将返回的 State 挂载到 `ns` 值命名的字段下。例如,`ns` 设置为 `data`,返回的 State 结构为:
46
46
 
@@ -96,7 +96,7 @@ interface State {
96
96
  ```
97
97
 
98
98
 
99
- ## 返回值
99
+ ### 返回值
100
100
 
101
101
  分别处理 pending、fulfilled、rejected 三种状态的 Action 组成的对象。
102
102
 
@@ -3,7 +3,7 @@ sidebar_position: 1
3
3
  title: model
4
4
  ---
5
5
 
6
- import ReduckTip from '@site/docs/components/reduck-tip.md'
6
+ import ReduckTip from '@site-docs/components/reduck-tip.md'
7
7
 
8
8
  <ReduckTip />
9
9
 
@@ -31,7 +31,7 @@ model('foo');
31
31
 
32
32
  `function define(modelDesc: ModelDesc): Model;`
33
33
 
34
- - modelDesc: `ModelDesc`,是对 Model 结构的定义,包含 `state`、`computed`、`actions`、`effects` 等属性。
34
+ - modelDesc: `ModelDesc`,对 Model 结构的定义,包含 `state`、`computed`、`actions`、`effects` 等属性。
35
35
 
36
36
  ```tsx title="示例"
37
37
  const fooModel = model('foo').define({
@@ -105,7 +105,7 @@ const barModel = model('bar').define((_, { use }) => {
105
105
 
106
106
  #### ModelDesc.state
107
107
 
108
- 定义 Model 的状态。技术上,支持任意类型的 **state**,但是实践中建议使用可进行 JSON 序列化的类型。
108
+ 定义 Model 的状态。技术上,支持任意类型的 **State**,但是实践中建议使用可进行 JSON 序列化的类型。
109
109
 
110
110
  ```ts
111
111
  interface ModelDesc {
@@ -3,11 +3,11 @@ sidebar_position: 4
3
3
  title: useLocalModel
4
4
  ---
5
5
 
6
- import ReduckTip from '@site/docs/components/reduck-tip.md'
6
+ import ReduckTip from '@site-docs/components/reduck-tip.md'
7
7
 
8
8
  <ReduckTip />
9
9
 
10
- 用于把 Model 中的 State 作为局部状态使用,效果类似 React 的 `useState`。`useStaticModel` API 形式上与 `useModel` 完全一致。具体使用请参考 [`useModel`](./use-model.md)。
10
+ 用于把 Model 中的 State 作为局部状态使用,效果类似 React 的 `useState`。`useLocalModel` API 形式上与 `useModel` 完全一致。具体使用请参考 [`useModel`](./use-model.md)。
11
11
 
12
12
 
13
13
  #### 示例
@@ -3,7 +3,7 @@ sidebar_position: 2
3
3
  title: useModel
4
4
  ---
5
5
 
6
- import ReduckTip from '@site/docs/components/reduck-tip.md'
6
+ import ReduckTip from '@site-docs/components/reduck-tip.md'
7
7
 
8
8
  <ReduckTip />
9
9
 
@@ -11,6 +11,7 @@ import ReduckTip from '@site/docs/components/reduck-tip.md'
11
11
  Reduck 原始类型较为复杂,以下涉及类型定义的地方,展示的是简化后的类型信息。原始类型见 [model](https://github.com/modern-js-dev/reduck/blob/main/packages/store/src/model/useModel.ts)。
12
12
  :::
13
13
 
14
+ ## 函数签名
14
15
 
15
16
  ```ts
16
17
  function useModel(
@@ -25,20 +26,18 @@ function useModel(
25
26
  ): [state, actions, subscribe];
26
27
  ```
27
28
 
28
-
29
- ## 参数
29
+ ### 参数
30
30
 
31
31
  - models:Model 对象数组,可以作为一个数组类型的参数传入,也可以所有 Model 逐个作为参数传入。
32
32
  - stateSelector:可选参数,用于筛选 State 计算。前 n 个参数为 n 个 Model 对应的 State,返回的数据作为 `useModel` 返回值数组的第一个元素。
33
33
  - actionSelector:可选参数,用于筛选 Actions 计算。前 n 个参数为 n 个 Model 对应的 Actions,返回的数据作为 `useModel` 返回值数组的第二个元素。
34
34
 
35
-
36
- ## 返回值
35
+ ### 返回值
37
36
 
38
37
  返回一个数组,每一项元素分别为:
39
38
 
40
- - state: `stateSelector` 的返回值。如果未传 `stateSelector`,会把传入的所有 Model 的 State (包含衍生状态)合并后返回。如果不同 Model 的 State 中存在同名属性,后面的 State 会覆盖前面的 State 。当 `state` 发生变化时,调用 `useModel` 的组件会重新渲染。
41
- - actions:第二个元素为 `actionSelector` 的返回值。如果未传 `actionSelector`,会把传入的所有 Model 的 Actions (包含 Effects) 合并后返回。如果不同 Model 的 Actions 中存在同名属性,后面的 Actions 会覆盖前面的 Actions
39
+ - state:`stateSelector` 的返回值。如果未传 `stateSelector`,会把传入的所有 Model 的 State (包含衍生状态)合并后返回。如果不同 Model 的 State 中存在同名属性,后面的 State 会覆盖前面的 State。当 `state` 发生变化时,调用 `useModel` 的组件会重新渲染。
40
+ - actions:第二个元素为 `actionSelector` 的返回值。如果未传 `actionSelector`,会把传入的所有 Model 的 Actions (包含 Effects) 合并后返回。如果不同 Model 的 Actions 中存在同名属性,后面的 Actions 会覆盖前面的 Actions。
42
41
  - subscribe:订阅 State 变化的函数。当传入的任意 Model 的 State 发生改变时,该函数会被调用。
43
42
 
44
43
  ## 示例
@@ -3,7 +3,7 @@ sidebar_position: 3
3
3
  title: useStaticModel
4
4
  ---
5
5
 
6
- import ReduckTip from '@site/docs/components/reduck-tip.md'
6
+ import ReduckTip from '@site-docs/components/reduck-tip.md'
7
7
 
8
8
  <ReduckTip />
9
9
 
@@ -27,7 +27,7 @@ function App() {
27
27
 
28
28
  #### 示例
29
29
 
30
- 如下 `App` 组件消费了 `userModel` 的状态,但没有直接在 JSX 里使用。如果 `userModel` 状态的改变会引起组件重新渲染,这是没有必要的,这种情况可以使用 `useStaticModel` 进行优化。
30
+ 如下 `App` 组件消费了 `userModel` 的状态,但没有直接在 JSX 里使用。可以发现,`userModel` 状态的改变没有必要引起组件重新渲染,这种情况可以使用 `useStaticModel` 进行优化。
31
31
 
32
32
  ```tsx
33
33
  function App() {