基于Vue以及iView组件的后端管理UI模板——iview-admin

boyanx3个月前技术教程16

介绍

iView-admin是一套后端管理界面模板,基于Vue2.0,iView(现在为View UI)组件是一套完整的基于Vue的高质量组件库,虽然Github上有一套非常火的基于Element UI的管理界面模板,但是多一种选择总是好的,本文就带大家一起看看这套UI,如果刚好适合你,那必然值得一试!



github

仓库:
https://github.com/iview/iview-admin

文档:
https://lison16.github.io/iview-admin-doc/#/

官网: https://www.iviewui.com/

概述

iView-admin是iView生态中的成员之一,是一套采用前后端分离开发模式,基于Vue的后台管理系统前端解决方案。iView-admin2.0脱离1.x版本进行重构,换用Webpack4.0 + Vue-cli3.0作为基本开发环境。内置了开发后台管理系统常用的逻辑功能,和开箱即用的业务组件,旨在让开发者能够以最小的成本开发后台管理系统,降低开发量。



快速开始

从github获取最新的iView-admin代码,使用如下命令获取2.0分支最新代码:

git clone https://github.com/iview/iview-admin.git -b 2.0

然后进入项目根目录

cd iview-admin

安装依赖并运行项目

npm install
npm run dev

然后只需要等待编译结束后其自动打开页面

模板介绍

1、模板整体上分为三大块,与传统布局方式无异,自带tab标签页,预览截图如下:

2、组件介绍

由于是基于iView的,因此iView 的组件都可以使用,一起瞧一瞧

  • 树组件:

  • 拖拽

  • 抽屉

  • 组织结构

  • 树状表格

  • 图片裁剪

  • 多功能数据表格

  • 窗口分割

  • 文本编辑器

  • 图标自定义

  • 文件上传

  • 粘贴数据表格

  • 上传和导出Excel

  • 动态标签路由

  • 可拖动模态框

  • 多级菜单

  • 项目目录结构

权限控制

权限控制分两种,即整个页面具有权限控制,和页面中单个组件需要权限。

1.整个页面访问限制

整个页面的权限控制较为简单,你只需要在路由配置的meta中配置access字段即可,它是一个数组,如果你没有设置access字段,那么该页面是所有用户都可以访问的;如果你设置了该字段,那么只有该字段所设置的数组中包含的权限名称的用户可访问该页面。 如下:

{
 path: '/page1',
 name: 'page1',
 component: Main,
 meta: {
 access: ['super_admin'] /*
 * 该页面只有权限值为super_admin的用户才能访问
 * 如果这级路由有子路由,则子路由也只有super_admin才能访问
 * 如果不设置此字段,则所有用户均可访问
 */
 }
}

2.单个组件浏览控制

如果你的一个页面上有多个组件,而不同的组件对于权限的要求又有所不同,那么,你可以使用如下方法给一个组件设置根据权限值配置它的可访问性:

<template>
 <div>
 <component1 v-if="viewAccessAll"></component1>
 <component2 v-if="viewAccessSuper"></component2>
 </div>
</template>
<script>
import { hasOneOf } from '@/libs/tools'
export default {
 name: 'page',
 computed: {
 access () {
 return this.$store.state.user.access
 },
 viewAccessAll () {
 return hasOneOf(['super_admin', 'admin'], this.access)
 },
 viewAccessSuper () {
 return hasOneOf(['super_admin'], this.access)
 }
 }
}
</script>

上面的例子中,admin和super_admin权限的用户都可看到component1组件,而component2只有super_admin可以看到。

全局指令

draggable

该指令作用于组件上,用于实现任意组件的可拖拽效果

<Button v-draggable="buttonOptions" id="button"></Button>
buttonOptions: {
 trigger: '#button', // 设置能触发拖动的元素的CSS选择器
 body: '#button' // 设置需要移动的元素的CSS选择器
}

接口请求

在iview-admin2.0对axios进行了封装,如果你需要调用接口,步骤如下:

step1

在./src/api目录中定义接口调用方法,拿获取表格数据来做示范,在api文件夹下创建data.js,然后在内部定义如下:

import axios from '@/libs/api.request'
export const getTableData = () => {
 return axios.request({ // 这里返回的是一个Promise,request方法传入一个配置对象,配置项可参考axios
 url: 'get_table_data',
 method: 'get'
 })
}

step2

在使用的地方如下:

import { getTableData } from '@/api/data'
getTableData().then(res => {
 this.tableData = res.data
}).catch(err => {
 console.log(err)
})

总结

对于程序员来说,特别是专注于中后端的程序员来说,一套完整的UI框架能够节省很多时间,提高工作效率,如果iView-admin刚好适合你,不妨试一试!下面是最近很火的一首程序员之歌,enjoy it!



标签: vueadmin

相关文章

宝塔搭建实战人才求职管理系统admin前端vue源码(二)

大家好啊,我是测评君,欢迎来到web测评。上一期给大家分享骑士cms后台端在宝塔的搭建部署方式,这套系统是前后端分离的架构,前端是用vue2开发的,还需要在本地打包手动发布上宝塔,所以本期给大家分享,...

1.8K Star!Cool-Admin-Vue:AI编码+流程编排,重新定义后台开发

「小墨是前端」专注分享前端技术,推荐优秀的开源项目,展示Github、Gitee上的创意作品,带你深入前端底层,一起成长。大家好!我是小墨,本期给大家推荐一个超酷的后台权限管理系统—— Cool-Ad...

国内首个纯净vue3+admin框架,同时支持电脑、手机、平板,多特性

#挑战30天在头条写日记##程序员#大家好我是仁杰,今天给大家分享一套国内首个纯净vue3 admin框架,同时支持电脑、手机、平板,默认分支使用vue3+antdv开发,master分支使用的v...

vue-admin-template处理token失效

token失效后应该删除token使其跳转至登录页面,而不是报401错误。1.在request.js的拦截器的位置添加401的判断,在此进行token的删除和跳转跳转要导入路由import { rou...

【开源】一款高效优雅的 Vite+Vue3 中后台管理模板——Arco-Admin

今天给大家分享一款开源的基于 Vite、TypeScript 和 Vue 3 的中后台前端框架,结合了 Arco Design 提供的优雅设计与强大功能。值得一提的是,Arco Design 是字节跳...

基于 Vue3+Ts 后台前端管理系统Vue3-Admin

今天再给大家分享一款超不错的Vue中后台管理系统Vue3Admin。vue3-admin 基于VueCli4+Ts+ElementUI构建的后台系统。采用组件化开发模式及Flex布局,支持移动端适配。...

发表评论    

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。