vue权限控制菜单显示
对于不同角色显示不同的菜单
思路1:
本地放一份完整的菜单数据,通过后台返回角色的菜单列表两者对比,筛选需要显示的菜单数据绑定,这里有个问题就是路由vue实例初始化就生成了,加载的全部,人为输入地址是可以访问到角色权限以外的数据,所以还要加路由构子router.beforeEach()去做判断哪些是角色权限以内的路由。这种思路的比较复杂,逻辑比较多
思路2:
利用Vue Router官方API提供的router.addRoutes()方法动态添加路由来实现
本章按思路2来实现该功能
1.初始化路由组件先定义出来,比如404、login组件
import Vue from 'vue'
import Router from 'vue-router' Vue.use(Router) export default new Router({
routes: [
{
path: '/login',
name: 'login',
component: () => import('@//components/login')
},
{
path: '*',
name: '404',
component: () => import('@//components/404')
}
]
})
2.login组件
<script>
import {mapActions} from 'vuex'
export default {
name: 'login',
data() {
return {
user: {
username: '',
password: ''
},
loading: false,
}
},
methods: {
...mapActions({add_Routes: 'add_Routes'}), handleLogin() {
// 这里为了方便就设置两个用户,其它不允许
if (this.user.username !== 'common' && this.user.username !== 'admin') {
return
}
this.loading = true
this.$api.login(this.user.username, this.user.password).then((res) => {
if (res.status === 200) {
// 将路由信息,菜单信息,用户信息存到sessionStorage里
sessionStorage.setItem('menuData', JSON.stringify(res.data.navData))
sessionStorage.setItem('user', this.user.username)
sessionStorage.setItem('routes', JSON.stringify(res.data.routerData))
this.add_Routes(res.data.routerData) //触发vuex里的增加路由
}
})
}
},
}
</script>
登录时从后台得到菜单数据navData和路由数据routerData把它存进sessionStorage防止刷新页面时丢失,引入vuex的this.add_Router()触发
3.vuex
import {ADD_ROUTES} from './mutations_type'
import Menufilter from './menufilter'
import router from '../router'
const addRoutes = {
state: {
routeData: []
},
mutations: {
[ADD_ROUTES](state, addrouter) {
let routes = []
Menufilter(routes, addrouter) // 将后台的路由数据components转化成组件
router.addRoutes(routes) // 添加路由
router.push('/')
}
},
actions: {
add_Routes({commit}, addrouter) {
commit(ADD_ROUTES, addrouter)
}
}
}
export default addRoutes
login组件的this.add_Router触发mutations里的ADD_ROUTES,ADD_ROUTES会做如下:
1. Menufilter(route, addrouter)会处理后台返回的路由数据,因为后台返回的数据中的components对应的是字符串应该把它转化成组件
import {lazy} from './lazyLoading'
export default (routers,data) => {
//要重新遍历一下,是因为,通常我们动态路由的时候,
//是获取服务端数据,这个component属性是一个字符串转化成组件
generaMenu(routers,data)
}
function generaMenu(routers,data){
data.forEach((item)=>{
let menu = Object.assign({},item)
menu.component = lazy(menu.component)
if(item.children){
menu.children = []
generaMenu(menu.children,item.children)
}
routers.push(menu)
})
}
// 懒加载组件lazy
function lazy(name) {
let file = name.split('_')[0]
if (name !== 'dashboard') {
return () => import(`@/page/${file}/${name}.vue`)
} else {
return () => import(`@/components/${name}.vue`)
}
}
export {lazy}
2. 调用router.addRouter(routes)动态添加路由
为了防止用户手动刷新页面还要在main.js重新触发vuex里的add_Routes方法添加路由
import Vue from 'vue'
import App from './App'
import router from './router'
import Element from 'element-ui'
import store from './store/store'
import 'element-ui/lib/theme-chalk/index.css'
import api from './api/api' Vue.config.productionTip = false
Vue.prototype.$api = api
Vue.use(Element)
// 用户手动刷新页面,这是路由会被重设,要重新新增
if (sessionStorage.getItem('user')) {
let routes = JSON.parse(sessionStorage.getItem('routes'))
store.dispatch("add_Routes", routes)
}
// 登录状态判断
router.beforeEach((to, from , next) => {
if (!sessionStorage.getItem('user') && to.path !== '/login') {
next({
path: '/login',
query: {redirect: to.fullPath}
})
} else {
next()
}
})
new Vue({
el: '#app',
store,
router,
components: { App },
template: '<App/>'
})
以上即可实现简单的权限菜单
vue权限控制菜单显示的更多相关文章
- vue权限控制菜单显示的简单实现
为了对于不同角色显示不同的菜单 思路1: 本地放一份完整的菜单数据,通过后台返回角色的菜单列表.两者对比,筛选需要显示的菜单数据绑定, 这里有个问题就是路由vue实例初始化就生成了,加载的全部,人为输 ...
- django 权限设置-菜单显示
问题:在用户登录后,如何只显示出用户权限的菜单呢?需要设置显示菜单权限 1.为了显示菜单,需要在models权限上添加is_menu(手动判断是否是查看)的icon(图标字符串) 在rbac中录入另一 ...
- MVC基于角色权限控制--菜单展示
在用户成功登陆后台页面后,我们需要将当前用户拥有的权限通过菜单的形式展现出来,将未具备的权限隐藏 新建一个HomeController,用于展示后台首页和获取用户权限数据 namespace CZBK ...
- 基于Vue实现后台系统权限控制
原文地址:http://refined-x.com/2017/08/29/基于Vue实现后台系统权限控制/,转载请注明出处. 用Vue/React这类双向绑定框架做后台系统再适合不过,后台系统相比普通 ...
- vue中如何实现后台管理系统的权限控制
vuejs单页应用的权限管理实践 一.前言 在广告机项目中,角色的权限管理是卡了挺久的一个难点.首先我们确定的权限控制分为两大部分,其中根据粒的大小分的更细: 接口访问的权限控制 页面的权限控制 菜单 ...
- yii2 rbac权限控制之菜单menu详细教程
作者:白狼 出处:http://www.manks.top/article/yii2_rbac_menu本文版权归作者,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则 ...
- yii2权限控制rbac之菜单menu最详细教程
前面我们在博文 yii2搭建完美后台并实现rbac权限控制实例教程中完美实现了yii2的后台搭建和rbac权限控制,如果你还没有实现,请先看上文再回来参考本文,因为本文是在上文的基础上进行完善和补充. ...
- vue项目权限控制
Vue权限控制有各种方法,大概分为两个方向: 把当前角色对应的权限保存在浏览器本地(容易被恶意修改): 将操作权限保存在vuex中(推荐此种方式:页面一刷新就没了,可以再次向后端请求相关数据,始终保持 ...
- vue-quasar-admin 一个包含通用权限控制的后台管理系统
vue-quasar-admin Quasar-Framework 是一款基于vue.js开发的开源的前端框架, 它能帮助web开发者快速创建以下网站:响应式网站,渐进式应用,手机应用(通过Cor ...
随机推荐
- spring - constructor-arg的常规用法
1.使用构造子注入时,则使用constructor-arg子标签,来指定构造函数的参数. <bean id="provider" class="com.ap ...
- Python内存机制简介
1: 变量不是盒子,应该把变量视作便利贴.变量只不过是标注,所以无法阻止为对象贴上多个标注.标注就是别名: >>> a = [1, 2, 3] >>> b = a ...
- Kubernetes Ingress日志分析入门
本文主要介绍如何基于日志服务构建Kubernetes Ingress日志分析平台,并提供一些简单的动手实验方便大家快速了解日志服务相关功能. 部署Ingress日志方案 登录容器服务管理控制台. 将上 ...
- UVa 10502【dp】
uva 10502 题意:给定01矩阵,求有多少个由1构成的矩阵.1本事也算一个矩阵. 到最后还是想不出来..... 每次枚举两行,从第i行到第j行,k枚举矩阵的宽(column).这样就相当于每次看 ...
- hdu 1950 最长上升子序列(lis) nlogn算法【dp】
这个博客说的已经很好了.http://blog.csdn.net/shuangde800/article/details/7474903 简单记录一下自己学的: 问题就是求一个数列最长上升子序列的长度 ...
- 使用 EnumWindows 找到满足你要求的窗口 - walterlv
原文:使用 EnumWindows 找到满足你要求的窗口 - walterlv 使用 EnumWindows 找到满足你要求的窗口 2019-04-30 13:11 在 Windows 应用开发中,如 ...
- Part17—触摸屏显身手—Part17.1—原理简介
- PAN-OS 6.1 Open Source Software (OSS) Listing
https://www.paloaltonetworks.com/documentation/oss-listings/oss-listings/pan-os-oss-listings/pan-os- ...
- behavior planning——11 create a cost function speed penalty
A key part of getting transitions to happen when we want them to is the design of reasonable cost ...
- 记一次sublime text3更新 注册码失效问题和永久解决~
前言: 一段时间不用sublime,打开提示我更新,不知怎么想的鬼使神差给点了~ 然后喵喵喵??? 取消 一会又出来了 受不了啦 搞事开整~ 正文: 本想直接找个注册码完事,奈何好多都用不了,想着再更 ...