0


vue3+element-plus的后台管理系统模板 和 vue3+ant-design-vue的后台管理系统模板

项目介绍

规范:后台系统模板,按照企业级别的规范搭建的。
权限控制:通过后端返回的路由表(这个路由表是由前端这边在系统配好的然后存储在后端的)来动态渲染菜单和注册路由,同时也根据页面内的接口权限对页面中的按钮做了是否可见的设置。前端这边有

路由、角色、用户管理

3个模块来控制权限,配权限找到这3个模块一步步配就行了。
功能模块封装:对

axios

进行了封装;封装了

pinia

持久化插件;封装了判断按钮权限的函数;封装了自定义hook来操作

vue-i18n

的国际化;封装了基于浏览器存储的自定义存储方式;封装了常用的工具函数。
组件封装:封装了快捷标签导航;封装了查询面板表单;对

el-table

做了进一步封装,通过表头配置来生成繁琐的dom结构;对

el-menu

就行了进一步封装,通过树形数据即可渲染出对应菜单;封装了

icon

组件。
细节处理:对组件库就行了主题和按需引入配置;动态计算布局内容和表格的高度,尽量不让纵向出滚动条且内容会刚好占满全屏;根据当前项目运行环境的不同做了一些不同的处理;可通过路由项的

meta

配置来决定此页面是否缓存、是否需要菜单、是否需要布局等等;

路由、角色、用户管理

这3个模块我已经写好,很多细节可以参考这3个模块的代码;基本没有多余的代码,然后你要用的话,直接下载然后改改样式、主题、封装一些你需要的功能组件和功能函数就可以直接写页面了,基本是开箱即用。

项目教学

项目开源地址(element-plus版)https://gitee.com/gitee_lw/element-plus-admin
项目开源地址(ant-design-vue版)https://gitee.com/gitee_lw/antd3-vue-admin.git
下面使用

element-plus

版来介绍项目。两个版本的逻辑业务用的同一套,就是组件库的差别。

下载及运行

1.通过开源地址找到仓库地址,使用仓库地址把项目克隆下来

git clone https://gitee.com/gitee_lw/element-plus-admin.git
#或者git https://gitee.com/gitee_lw/antd3-vue-admin.git

2.安装依赖

yarn# 推荐使用yarn安装npm i  # 或者把 yarn.lock文件删除使用npm安装

3.启动项目

yarn start
或者 npm run start

4.登录系统
![在这里插入图片描述](https://img-blog.csdnimg.cn/ef2ae908cad74b61ad7d0525098105bb.png

这是初始化的一张用户表,里面有3个账号,密码同用户名,例:userName是admin,则密码也是 admin
,登录时就是像下面这样,admin这个账号是最高权限账号。
![在这里插入图片描述](https://img-blog.csdnimg.cn/d59c42292ae54786a6af3f0699d8fe2b.png

登录后,主要看这些模块
![在这里插入图片描述](https://img-blog.csdnimg.cn/9fe64d1810ea4b679576231d32ab54aa.png
在这里插入图片描述

了解项目目录结构

在这里插入图片描述

了解项目技术选型

在这里插入图片描述

权限逻辑核心代码

全局路由守卫,判断是否具备访问某个页面的权限(“@/router/permission.ts”)
在这里插入图片描述

该模块由于管理 系统菜单和当前用户所具备权限的路由表(“@/store/modules/routes.ts”)
在这里插入图片描述页面、菜单权限演示
在这里插入图片描述

判断是否具备某个按钮的权限(“@/common/addGlobalProperty.ts”)里的

hasAuth

函数,我已经将这个函数挂在全局上了
在这里插入图片描述根据具备的按钮权限来控制按钮是否显示的使用示例
在这里插入图片描述

关于自定义存储

代码见

@/commom/utils.ts

中的函数

creatBs

在这里插入图片描述

自定义存储类似于

vue-ls

,这是我自己封装的,相对于

vue-ls

更加轻量,通过函数返回的自定义存储对象灵活性高,存储的值可以设置过期时间、是否加密、存储键名的前缀。

pinia持久化的使用

找到文件

@/store/install/index.ts

在这里插入图片描述函数

storagefyPlus

传递一个配置对象,

key

是pinia模块的

id

value

是持久化的存储方式,值类型是数字的话代表使用的是我封装的自定义存储,数字的话代表过期时间(0代表不过期),如果是

'localStorage'

则代表使用的是

localStorage

的存储方式。

国际化的使用

1.配置词汇
在这里插入图片描述2.使用
在这里插入图片描述3.效果演示

在这里插入图片描述

4.更多使用参考语言切换组件

@/layouts/components/selectLang.vue

自定义表格组件的使用

1.引入基于

el-table

封装的表格,

import MyTable from "@/components/Table/myTable.vue";

2.编写表头配置
在这里插入图片描述

3.使用组件生成表格
在这里插入图片描述4.表格的表头配置支持自定义渲染头或者列内容、多级表头渲染
在这里插入图片描述

5.表格支持插槽渲染,插槽名同列配置的

prop

属性,头部具名作用域插槽的渲染需要额外加

-header

后缀。表格也支持分页配置来渲染分页器
在这里插入图片描述

查询面板组件的使用

1.引入组件

import searchPanel from '@/components/SearchPanel'

2.提供组件需要的状态

const searchOptions=ref<searchOptionType[]>([{type:'input',id:'userName',props:{label:'用户名'}},{type:'input',id:'nickName',props:{label:'昵称'}},{type:'select',id:'role',props:{label:'角色'},innerComponentProps:{filterable:true,selectOptions:[// { label: '商品类型1', value: '1',disabled:false },],}},])// type是表单项类型,id是表单项属性,props是el-form-item的props,innerComponentProps的el-form-item内部包裹组件的props。额外为el-select提供selectOptions属性,用于渲染el-option

3.使用组件

<search-panel:options="searchOptions"@collapsed="setTableHeight"@reset="reset"@search="search"/>

4.渲染效果
![在这里插入图片描述](https://img-blog.csdnimg.cn/624a402b642a4125915bd05750700797.png当查询选项大于一行时,会出现折叠展开按钮
在这里插入图片描述

其他推荐

如果不喜欢用

element-plus

,我用

ant-design-vue

也写了一套,逻辑和这套系统一模一样,就是换了个组件库
项目开源地址:https://gitee.com/gitee_lw/antd3-vue-admin.git

效果演示

在这里插入图片描述

结尾

有什么不懂的地方,欢迎提问。


本文转载自: https://blog.csdn.net/qq_61233877/article/details/131008600
版权归原作者 Melody_lw 所有, 如有侵权,请联系我们删除。

“vue3+element-plus的后台管理系统模板 和 vue3+ant-design-vue的后台管理系统模板”的评论:

还没有评论