使用React18
,Typescript
,Vite
,Antd5.0
等主流技术开发的开箱即用的中后台前端项目,Vite
实现自动生成路由,支持KeepAlive
功能,zustand
状态管理,支持虚拟滚动表格,UnoCss
开发样式。
- 获取项目代码
git clone https://github.com/southliu/react-admin.git
- 选择目录
cd react-admin
- 安装全局依赖依赖,存在则不用安装
npm i -g pnpm
- 安装依赖
pnpm install
pnpm config set registry https://registry.npm.taobao.org/
- 运行
pnpm dev
- 打包
pnpm build
- 切换redux分支即可
- 参考 iconify官方地址
- VS Code安装Iconify IntelliSense - 图标内联显示和自动补全
git add .
git commit -m "feat: 新增功能"
git push
-
参考 vue 规范
feat
增加新功能fix
修复问题/BUGstyle
代码风格相关无影响运行结果的perf
优化/性能提升refactor
重构revert
撤销修改test
测试相关docs
文档/注释chore
依赖更新/脚手架配置修改等workflow
工作流改进ci
持续集成types
类型定义文件更改wip
开发中
- 功能扩展,在原有的api上拓展。
- 功能整合,合并两个或两个以上组件的api。
- 样式统一,避免后期样式变动,导致牵一发而动全身。
- 公共组件二次封装或常用组件使用Base开头,便于区分。
- 通过登录接(/login/v2)或重新授权接口(/authority/user/refresh-permissions/v2)获取permissions权限数据。
- 通过菜单接口(/menu/list/v3)获取data中的rule权限数据,这个rule数据影响菜单显示,如果没返回rule则一直都显示。
- 页面内权限参考src/pages/system/menu.index.tsx文件内的pagePermission数据,pagePermission.page是显示页面的权限,根据第一点返回的permissions进行匹配。
路由根据文件夹路径自动生成,路径包含以下文件名或文件夹名称则不生成:
- components
- utils
- lib
- hooks
- model.tsx
- 404.tsx
可自行在 src/router/utils/config.ts 修改路由生成规则。
提供了两种方式配置菜单:
- 动态菜单,通过菜单接口(/menu/list/v3)获取菜单数据。
- 静态菜单,需要静态菜单将useCommonStore中的menuList改为defaultMenus
// src/hooks/useCommonStore.ts
import { defaultMenus } from '@/menus';
// const menuList = useMenuStore(state => state.menuList);
// 菜单数据
const menuList = defaultMenus;
通过根目录packages
文件中查看对于xxx文件的源码进行修改。