你知道光是基于 Vue 的后台框架在 Github 上有多少个仓库么?html
若是你搜索 vue admin
会获得 13120 个仓库,若是用 vue 后台
会获得 7596 个仓库,若是把二者结合一下,搜索 vue admin 后台
也仍是能获得 2719 个(以上搜索统计截止至 2021/1/2)。vue
固然,若是你须要找一款后台框架用来作项目或者是产品,大几率你不会上 Github 现搜,国内有不少文章整理过值得一用的后台框架,例如 vue-element-admin 、d2-admin 、vue-antd-admin 等等,但只有这些了么?git
今天,就给你们正式介绍一款值得进入你收藏夹吃灰你在 2021 年关注的后台框架:浏览器
Fantastic-admin —— 一款开箱即用的 Vue 中后台管理系统框架缓存
后台框架这么多,Fantastic-admin 为何值得你去了解,它又有什么亮点,下面就简单介绍一下。antd
Tip:如下部分介绍为专业版功能
我在以前的《收下这款 Vue 项目模版,它将让你的开发效率在 2021 年提升 50%》这篇文章里介绍过 vue-automation 这款 Vue 项目模版,它集成了不少不错的特性能够方便在开发中直接使用,而必备浪费太多时间,而 Fantastic-admin 也继承了大部分特性。框架
双侧边栏布局 | 头部导航布局 | 单侧边栏布局 |
<img src="https://hooray.gitee.io/fantastic-admin/basic-layout-default.png" /> | <img src="https://hooray.gitee.io/fantastic-admin/basic-layout-header.png" /> | <img src="https://hooray.gitee.io/fantastic-admin/basic-layout-without-main-sidebar.png" /> |
自适应 | 自适应(有最小宽度) | 定宽居中 | 定宽居中(有最大宽度) |
<img src="https://hooray.gitee.io/fantastic-admin/layout_1.gif" /> | <img src="https://hooray.gitee.io/fantastic-admin/layout_2.gif" /> | <img src="https://hooray.gitee.io/fantastic-admin/layout_3.gif" /> | <img src="https://hooray.gitee.io/fantastic-admin/layout_4.gif" /> |
除此以外,还提供了 5 款内置主题风格的界面能够选择ide
默认 | Vue CLI 风格 | 码云风格 | 清新 | 素雅 |
<img src="https://s3.ax1x.com/2021/01/02/sSUJRP.png" /> | <img src="https://s3.ax1x.com/2021/01/02/sSNO5n.png" /> | <img src="https://s3.ax1x.com/2021/01/02/sSNqEj.png" /> | <img src="https://s3.ax1x.com/2021/01/02/sSN7Dg.png" /> | <img src="https://s3.ax1x.com/2021/01/02/sSNHbQ.png" /> |
固然,也提供的自定义配置主题的文件,可快速扩展一套自定义风格的主题。函数
经过路由配置生成菜单导航是后台框架的必备功能,除此以外,路由配置还支持外链、标记、权限等功能,而且还支持无限层级的页面缓存。布局
关于页面缓存的问题,以前我也特别写过一篇文章叫《一劳永逸,解决基于 keep-alive 的后台多级路由缓存问题》,感兴趣的小伙伴能够前往了解。
除了路由上的权限验证外,还分别提供了鉴权组件、鉴权指令和鉴权函数,提供全方位鉴权。
页面中某个模块,当前用户具有该权限是如何显示,不具有该权限又是如何显示,针对这样的需求,框架提供了 <Auth>
和 <AuthAll>
组件,具体使用以下:
<!-- 单权限验证 --> <Auth :value="'department.create'"> 你有该权限 <template slot="no-auth"> 你没有该权限 </template> </Auth> <!-- 多权限验证,用户只要具有其中任何一个权限,则验证经过 --> <Auth :value="['department.create', 'department.edit']"> 你有该权限 <template slot="no-auth"> 你没有该权限 </template> </Auth> <!-- 多权限验证,用户必须具有所有权限,才验证经过 --> <AuthAll :value="['department.create', 'department.edit']"> 你有该权限 <template slot="no-auth"> 你没有该权限 </template> </AuthAll>
对于单个元素,也提供了 v-auth
和 v-auth-all
鉴权指令,使用上对比鉴权组件更方便,固然它能作的事情也更简单。
<!-- 单权限验证 --> <button v-auth="'department.create'">新增部门</button> <!-- 多权限验证,用户只要具有其中任何一个权限,则验证经过 --> <button v-auth="['department.create', 'department.edit']">新增部门</button> <!-- 多权限验证,用户必须具有所有权限,才验证经过 --> <button v-auth-all="['department.create', 'department.edit']">新增部门</button>
鉴权组件和鉴权指令控制的是页面上的元素是否展现,而鉴权函数则更可能是使用在业务流程代码里的权限判断。
// 单权限验证,返回 true 或 false this.$auth('department.create') // 多权限验证,用户只要具有其中任何一个权限,则验证经过,返回 true 或 false this.$auth(['department.create', 'department.edit']) // 多权限验证,用户必须具有所有权限,才验证经过,返回 true 或 false this.$authAll(['department.create', 'department.edit'])
虽然我我的以为这个功能挺鸡肋的,实际效果体验也不如浏览器原生的 tab 标签栏,但咱得有这功能。而且这功能目前在我看来,几乎秒杀了其它同类框架,用一张图简单演示下吧:
国际化的支持固然也不能少,默认提供了简体中文、繁体中文和英语三种语言包。
除了以上介绍的外,还支持 mock 、CDN 、GZip 等特性,就不一一详细介绍了,欢迎感兴趣的小伙伴能够来详情了解并使用 Fantastic-admin