2022-04-10 14:06:06 +08:00
|
|
|
|
<p align="center">
|
|
|
|
|
<a href="https://github.com/zclzone/vue-naive-admin">
|
|
|
|
|
<img alt="Vue Naive Admin Logo" width="200" src="https://assets.qszone.com/images/logo_qs.svg">
|
|
|
|
|
</a>
|
|
|
|
|
</p>
|
|
|
|
|
<p align="center">
|
|
|
|
|
<a href="https://github.com/zclzone/vue-naive-admin/actions"><img allt="checks" src="https://badgen.net/github/checks/zclzone/vue-naive-admin"/></a>
|
|
|
|
|
<a href="https://github.com/zclzone/vue-naive-admin"><img allt="stars" src="https://badgen.net/github/stars/zclzone/vue-naive-admin"/></a>
|
|
|
|
|
<a href="https://github.com/zclzone/vue-naive-admin"><img allt="forks" src="https://badgen.net/github/forks/zclzone/vue-naive-admin"/></a>
|
|
|
|
|
<a href="./LICENSE"><img allt="MIT License" src="https://badgen.net/github/license/zclzone/vue-naive-admin"/></a>
|
|
|
|
|
</p>
|
|
|
|
|
|
2022-01-09 23:25:00 +08:00
|
|
|
|
|
2022-04-05 17:35:05 +08:00
|
|
|
|
### 简介
|
2022-01-09 23:25:00 +08:00
|
|
|
|
|
2022-04-05 17:35:05 +08:00
|
|
|
|
[Vue Naive Admin](https://github.com/zclzone/vue-naive-admin),一个基于 Vue3.0、Vite、Naive UI 的后台管理模板,相较于其他比较流行的后台管理模板,此项目相对简洁、轻量,学习成本非常低,对新手极其友好。不过麻雀虽小五脏俱全,权限、Mock、菜单、axios 封装、pinia、项目配置、样式配置、环境配置,以及一些经常用的基础组件封装等等这些该有的都有,非常适用于中小型项目或者个人项目,也可此模板进行二次封装改造用于大型项目。
|
2022-01-09 23:25:00 +08:00
|
|
|
|
|
2022-04-05 17:35:05 +08:00
|
|
|
|
### 为什么要开发这个模板
|
2022-01-09 23:25:00 +08:00
|
|
|
|
|
2022-04-05 17:35:05 +08:00
|
|
|
|
- Vue3 和 Vite 已经趋于成熟,学习 vite 和 vue3 非常有必要,通过开发模板进行学习是一个很好的方式,事实也证明我确实从中获益良多
|
|
|
|
|
- 目前主流的 Vue3+Vite 后台管理模板都相对复杂,甚至感觉有点花里胡哨(没有贬低的意思,大部分的架构设计都很优秀,只是觉得集成了太多不实用的东西)
|
2022-01-09 23:25:00 +08:00
|
|
|
|
|
2022-04-05 17:35:05 +08:00
|
|
|
|
### 功能
|
2022-01-09 23:25:00 +08:00
|
|
|
|
|
2022-04-05 17:35:05 +08:00
|
|
|
|
- 🍒 集成 Naive UI,尤大推荐的 UI 组件库,[https://www.naiveui.com](https://www.naiveui.com)
|
|
|
|
|
- 🍑 集成登陆、注销及权限验证
|
2022-04-09 23:38:43 +08:00
|
|
|
|
- 🍐 集成多环境配置,dev、测试、生产和github pages环境
|
2022-04-05 17:35:05 +08:00
|
|
|
|
- 🍎 集成 Eslint + Prettier,代码约束和格式化统一
|
2022-01-25 15:19:49 +08:00
|
|
|
|
- 🍉 集成 Mock 接口服务,dev 环境和发布环境都支持,可动态配置是否启用 mock 服务,不启用时不会加载 mock 包,减少打包体积
|
2022-04-05 17:35:05 +08:00
|
|
|
|
- 🍇 集成 unocss,antfu 大神开源的原子化 css 解决方案,非常轻量,目前我是自己写 scss 样式搭配着 unocss 使用的
|
|
|
|
|
- 🍍 集成 Pinia,Vuex 的替代方案,轻量、简单、易用(尤大已表示不会有Vuex5,或者说pinia就是Vuex5)
|
|
|
|
|
- 📦 集成 Vite 自动导入插件unplugin-vue-components,解放双手,开发效率直接起飞
|
2022-04-10 14:06:06 +08:00
|
|
|
|
- 🤹 集成 unplugin-icons插件,优雅使用iconify图标
|
2022-04-05 17:35:05 +08:00
|
|
|
|
- 🍏 二次封装 Axios,支持多 axios 实例,支持线上环境免重新打包修改 baseURL
|
2022-01-25 15:19:49 +08:00
|
|
|
|
- 🍌 二次封装全局 Dialog、Message、LoadingBar 组件
|
|
|
|
|
- 🍋 二次封装 localStorage 和 sessionStorage,支持设置过期时间
|
2022-01-09 23:25:00 +08:00
|
|
|
|
|
2022-04-10 14:06:06 +08:00
|
|
|
|
### 预览
|
2022-02-14 14:05:40 +08:00
|
|
|
|
|
|
|
|
|
[template.qszone.com](https://template.qszone.com)
|
|
|
|
|
|
2022-04-10 14:06:06 +08:00
|
|
|
|
[github pages](https://zclzone.github.io/vue-naive-admin)
|
|
|
|
|
|
|
|
|
|
### 文档
|
2022-01-09 23:25:00 +08:00
|
|
|
|
|
2022-04-05 17:35:05 +08:00
|
|
|
|
[Vue Naive Admin Docs](https://zclzone.github.io/vue-naive-admin-docs)
|
2022-04-10 14:06:06 +08:00
|
|
|
|
|
2022-01-09 23:25:00 +08:00
|
|
|
|
[羽雀文档:Vue Naive Admin](https://www.yuque.com/qszone/vue-naive-admin)
|
|
|
|
|
|
2022-04-10 14:06:06 +08:00
|
|
|
|
### 构建
|
2022-01-09 23:25:00 +08:00
|
|
|
|
|
|
|
|
|
```shell
|
|
|
|
|
# 推荐配置git autocrlf 为 false(本项目规范使用lf换行符,此配置是为防止git自动将源文件转换为crlf)
|
|
|
|
|
# 不清楚为什么要这样做的请参考这篇文章:https://www.freesion.com/article/4532642129
|
|
|
|
|
git config --global core.autocrlf false
|
|
|
|
|
|
|
|
|
|
# 克隆项目
|
|
|
|
|
git clone https://github.com/zclzone/vue-naive-admin.git
|
|
|
|
|
|
|
|
|
|
# 进入项目目录
|
|
|
|
|
cd vue-naive-admin
|
|
|
|
|
|
2022-02-18 15:28:15 +08:00
|
|
|
|
# 安装依赖(建议使用pnpm: https://pnpm.io/zh/installation)
|
|
|
|
|
pnpm i # 或者 npm i
|
2022-01-09 23:25:00 +08:00
|
|
|
|
|
|
|
|
|
# 启动
|
|
|
|
|
npm run dev
|
|
|
|
|
```
|
|
|
|
|
|
2022-04-10 14:06:06 +08:00
|
|
|
|
### 发布
|
2022-01-09 23:25:00 +08:00
|
|
|
|
|
|
|
|
|
```shell
|
|
|
|
|
# 构建测试环境
|
|
|
|
|
npm run build:test
|
|
|
|
|
|
2022-04-09 23:38:43 +08:00
|
|
|
|
# 构建github pages环境
|
|
|
|
|
npm run build:github
|
2022-01-09 23:25:00 +08:00
|
|
|
|
|
|
|
|
|
# 构建生产环境
|
|
|
|
|
npm run build
|
|
|
|
|
```
|
|
|
|
|
|
2022-04-10 14:06:06 +08:00
|
|
|
|
### 其他指令
|
2022-01-09 23:25:00 +08:00
|
|
|
|
|
|
|
|
|
```shell
|
|
|
|
|
# eslint代码格式检查
|
|
|
|
|
npm run lint
|
|
|
|
|
|
|
|
|
|
# 代码检查并修复
|
|
|
|
|
npm run lint:fix
|
|
|
|
|
|
|
|
|
|
# 预览发布包效果(需先执行构建指令)
|
|
|
|
|
npm run preview
|
|
|
|
|
```
|
2022-03-19 19:13:07 +08:00
|
|
|
|
|
2022-04-10 14:06:06 +08:00
|
|
|
|
### 规范
|
|
|
|
|
|
|
|
|
|
#### git commit 规范
|
2022-03-19 19:13:07 +08:00
|
|
|
|
|
|
|
|
|
- `feat` 增加新功能
|
|
|
|
|
- `fix` 修复问题/BUG
|
|
|
|
|
- `style` 代码风格相关无影响运行结果的
|
|
|
|
|
- `perf` 优化/性能提升
|
|
|
|
|
- `refactor` 重构
|
|
|
|
|
- `revert` 撤销修改
|
|
|
|
|
- `test` 测试相关
|
|
|
|
|
- `docs` 文档/注释
|
|
|
|
|
- `chore` 依赖更新/脚手架配置修改等
|
|
|
|
|
- `workflow` 工作流改进
|
|
|
|
|
- `ci` 持续集成
|
|
|
|
|
- `types` 类型定义文件更改
|
|
|
|
|
- `wip` 开发中
|
|
|
|
|
- `mod` 不确定分类的修改
|
2022-04-15 22:19:09 +08:00
|
|
|
|
- `release` 发布
|
2022-04-10 14:06:06 +08:00
|
|
|
|
|
2022-04-26 19:59:59 +08:00
|
|
|
|
|
|
|
|
|
注:此项目暂时没有集成TS,主要是为了照顾不会TS的同学,且此项目是定位于中小型项目或者个人项目的,所以更偏重于开发效率和开发体验,不集成TS明显是更佳的选择。
|
|
|
|
|
|
|
|
|
|
当然,后续也会增加TS版本,供喜欢TS的同学选择。
|
|
|
|
|
|
|
|
|
|
|