主要功能:
1.layout布局
2.router,pinia,axio,
3.element-ui plus 部分组件二次封装
4.多语言 / icon图标组件封装 / 多环境 / eslint
其他功能不定时更新...
线上地址:http://165.154.67.193:2000/
GitHub:github.com/jimoruyan/v…
gitee: gitee.com/wccy/vite-v…
`
1 概述
1.1 简介
vite-vue3-template是一个管理后台系统中前端解决方案,它基于 [vue] [element-ui-plus] [vite]实现。它使用了最新的前端技术栈,提炼了典型的业务模型,提供了丰富的功能组件,它可以帮助你快速搭建企业级中后台产品原型。
你需要在本地安装 node ,本项目技术栈基于[vue3] [pinia] [vue-router4] [axios] [vite2] [element-ui-plus] [ES2015+] ,所有的请求数据都使用[Mock.js]进行模拟,提前了解和学习这些知识会对使用本项目有很大的帮助。
1.2 功能(正在开发中)
- 登录 / 注销
- 权限验证 / 菜单构建 / 页面权限 / 多语言 / SVG图标管理
- 本地开发服务器 / 编码规范检测 / less支持
1.3 开发
// 推荐使用yarn来下载依赖及构建,yarn可以理解为npm的优化版本,如果没有安装要先安装yarn
npm install yarn -g
// 进入项目目录
cd vite-vue3-template
// 安装依赖
yarn install
// 可以通过如下操作解决 npm 下载速度慢的问题
npm install --registry=https://registry.npm.taobao.org
// 启动服务
yarn dev
1.4 发布
// 构建测试环境
yarn build:stage
// 构建生产环境
yarn build:prod
2 代码风格
本项目的风格指南主要是参照 vue 官方的风格指南。在真正开始使用该项目之前建议先阅读一遍指南,这能帮助让你写出更规范和统一的代码。当然每个团队都会有所区别。其中大部分规则也都配置在了eslint-plugin-vue之中,当没有遵循规则的时候会报错,详细内容见eslint章节。
当然也有一些特殊的规范,是不能被 eslint 校验的。需要人为的自己注意,并且来遵循。最主要的就是文件的命名规则,这里来举例说明。
如果使用vscode,可配置保存后自动按照 eslint 规则格式化代码
2.1 Component
所有的Component文件都是以大写开头 (PascalCase),这也是官方所推荐的。
但除了 index.vue。
例子:
@/src/components/BackToTop/index.vue@/src/components/Charts/Line.vue@/src/view/example/components/Button.vue
2.2 JS文件
所有的.js文件都遵循横线连接 (kebab-case)。
例子:
@/src/utils/open-window.js@/src/view/svg-icons/require-icons.js@/src/components/MarkdownEditor/default-options.js
2.3 View
在view文件下,代表路由的.vue文件都使用横线连接 (kebab-case),代表路由的文件夹也是使用同样的规则。
例子:
@/src/view/svg-icons/index.vue@/src/view/svg-icons/require-icons.js
使用横线连接 (kebab-case)来命名view主要是出于以下几个考虑。
- 横线连接 (kebab-case) 也是官方推荐的命名规范之一 文档
view下的.vue文件代表的是一个路由,所以它需要和component进行区分(component 都是大写开头)- 页面的
url也都是横线连接的,比如https://www.xxx.admin/export-excel,所以路由对应的view应该要保持统一 - 没有大小写敏感问题
2.4 ESlint检测
模板工程中配置ESlint检测,将开发环境中的的eslint配置文件设置为.eslintrc.js,或者设置为自动搜索配置。
3 目录结构
--public --资源目录,打包后不会被压缩 --src --api --平台接口 --assets --资源目录,打包后会压缩 --components --组件库 --hooks --常用hooks --icon --icon图标集 --layout --布局组件 --locales --多语言 --router --路由文件 --stoer --状态管理 --utils --常用工具类 --view --页面 --App.vue --入口页面 --main.js --入口方法 --.env --项目默认配置 --.env.* --对应环境的配置(会覆盖上面的.env配置)
4 pinia配置(状态存储)
模板中预置了user与app模块存储用户、项目信息,并定义了常用的getters,如果添加新的模块可直接再modules下添加对应的文件,代码会自动批量读取。
5 VueRouter配置(路由)
路由配置在src/router/index.js,新路由可在src/router/routes.js中添加
6 权限控制
6.1 页面权限
页面权限分两种情况,一种是未登录时可访问的页面,一种是登录后可访问的页面。
6.1.1 whiteList页面
例如登录页面肯定是要未登录即可访问的页面,配置哪些页面未登录就可访问是通过定义路由时meta中的whiteList属性来实现的。
whiteList为true时对应的路由不登录即可访问,如果不是未登录即可访问的路由,在没有登录前访问时都会自动跳转到登录页面。
7 打包部署
7.1 多环境
模板工程是基于Vue CLI 3创建的工程,多环境机制是由vue-cli实现的,在此只做简要说明,具体了解请参见[cli.vuejs.org/zh/guide/mo…]
.env.xxx是环境变量文件,如果要多定义一种环境,则增加一个环境变量文件,例如增加一个test环境,则先增加.env.test文件,再在其中增加相应的环境变量,构建test环境,使用命令
vue-cli-service build --mode test
建议将命令定义到package.json中便于以后使用,模板工程已经预置了production和stage的构建命令 使用package中的命令,可以进入项目文件夹后执行以下命令
// production构建
yarn run build:prod
// stage构建
yarn run build:stage
// 或者test这样构建,package.json需要提前定义"build:test": "vite build --mode test"
yarn run build:test
7.2 构建与部署
构建后会生成dist文件夹,部署到服务器上时,将dist全部内容部署上去,dist的名称需要根据情况修改。 `