- 脚手架:umi v4
- 组件库:antd v5
- 状态管理库 dva
- 图表库
- 国际化
目录结构 tree ./ -L 2 -I node_modules
- 所有的interfase 与 type 必须已I开头
interfase IState { name: string }
// goodinterfase State { name: string }
// bad
所有 key 参考格式为 模块名称.文案类型.文案描述
。若文案包含可变部分,可使用 {1}
、{2}
、{3}
代替。
src/i18n/index.ts
中默认导出 i18n
转换方法,可以将 key 转换为对应的实际文案。文案中的 {1}
将被替换为第二个入参,以此类推。例如:
// 'home.tip.welcome': '欢迎您,{1}!'
i18n('home.tip.welcome', user.name); // => '欢迎您,张三!'
也可以使用 src/i18n/index.ts
中导出的 i18nElement
方法,可以将文案中的占位符替换为 JSX 元素。例如:
i18nElement('home.tip.welcome', <b>{user.name}</b>); // => <>欢迎您,<b>张三</b>!</>'
├── dist
│ ├── index.html
│ ├── layouts__index.async.js
│ ├── layouts__index.chunk.css
│ ├── p__docs.async.js
│ ├── p__index.async.js
│ └── umi.js
├── package.json
├── readme.md
├── release
│ ├── Chat2DB-1.0.0-arm64-mac.zip
│ ├── Chat2DB-1.0.0-arm64-mac.zip.blockmap
│ ├── Chat2DB-1.0.0-arm64.dmg
│ ├── Chat2DB-1.0.0-arm64.dmg.blockmap
│ ├── builder-debug.yml
│ ├── builder-effective-config.yaml
│ └── mac-arm64
├── src
│ ├── assets
│ ├── blocks
│ ├── components
│ ├── config
│ ├── constant
│ ├── layouts
│ ├── locales
│ ├── main
│ ├── models
│ ├── pages
│ ├── typings
│ └── utils
├── tsconfig.json
├── typings.d.ts
└── yarn.lock