对于不同角色显示不同的菜单

思路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权限控制菜单显示的更多相关文章

  1. vue权限控制菜单显示的简单实现

    为了对于不同角色显示不同的菜单 思路1: 本地放一份完整的菜单数据,通过后台返回角色的菜单列表.两者对比,筛选需要显示的菜单数据绑定, 这里有个问题就是路由vue实例初始化就生成了,加载的全部,人为输 ...

  2. django 权限设置-菜单显示

    问题:在用户登录后,如何只显示出用户权限的菜单呢?需要设置显示菜单权限 1.为了显示菜单,需要在models权限上添加is_menu(手动判断是否是查看)的icon(图标字符串) 在rbac中录入另一 ...

  3. MVC基于角色权限控制--菜单展示

    在用户成功登陆后台页面后,我们需要将当前用户拥有的权限通过菜单的形式展现出来,将未具备的权限隐藏 新建一个HomeController,用于展示后台首页和获取用户权限数据 namespace CZBK ...

  4. 基于Vue实现后台系统权限控制

    原文地址:http://refined-x.com/2017/08/29/基于Vue实现后台系统权限控制/,转载请注明出处. 用Vue/React这类双向绑定框架做后台系统再适合不过,后台系统相比普通 ...

  5. vue中如何实现后台管理系统的权限控制

    vuejs单页应用的权限管理实践 一.前言 在广告机项目中,角色的权限管理是卡了挺久的一个难点.首先我们确定的权限控制分为两大部分,其中根据粒的大小分的更细: 接口访问的权限控制 页面的权限控制 菜单 ...

  6. yii2 rbac权限控制之菜单menu详细教程

    作者:白狼 出处:http://www.manks.top/article/yii2_rbac_menu本文版权归作者,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则 ...

  7. yii2权限控制rbac之菜单menu最详细教程

    前面我们在博文 yii2搭建完美后台并实现rbac权限控制实例教程中完美实现了yii2的后台搭建和rbac权限控制,如果你还没有实现,请先看上文再回来参考本文,因为本文是在上文的基础上进行完善和补充. ...

  8. vue项目权限控制

    Vue权限控制有各种方法,大概分为两个方向: 把当前角色对应的权限保存在浏览器本地(容易被恶意修改): 将操作权限保存在vuex中(推荐此种方式:页面一刷新就没了,可以再次向后端请求相关数据,始终保持 ...

  9. vue-quasar-admin 一个包含通用权限控制的后台管理系统

    vue-quasar-admin   Quasar-Framework 是一款基于vue.js开发的开源的前端框架, 它能帮助web开发者快速创建以下网站:响应式网站,渐进式应用,手机应用(通过Cor ...

随机推荐

  1. 【JZOJ3873】【NOIP2014八校联考第4场第2试10.20】乐曲创作(music)

    ujfuiaty 小可可是音乐学院的一名学生,他需要经常创作乐曲完成老师布置的作业. 可是,小可可是一个懒惰的学生.所以,每次完成作业时,他不会重新创作一首新的乐曲,而是去修改上一次创作过的乐曲作为作 ...

  2. Spark-day01

      Spark初始 什么是Spark Apache Spark 是专为大规模数据处理而设计的快速通用的计算引擎.Spark是UC Berkeley AMP lab (加州大学伯克利分校的AMP实验室) ...

  3. 2019-10-31-C#-强转空会不会出现异常

    title author date CreateTime categories C# 强转空会不会出现异常 lindexi 2019-10-31 8:53:6 +0800 2019-9-10 11:4 ...

  4. python的str,unicode对象的encode和decode方法, Python中字符编码的总结和对比bytes和str

    python_2.x_unicode_to_str.py a = u"中文字符"; a.encode("GBK"); #打印: '\xd6\xd0\xce\xc ...

  5. sql —— group by

    说明: 从字面意义上理解就是根据“By”指定的规则对数据进行分组,所谓的分组就是将一个“数据集”划分成若干个“小区域”,然后针对若干个“小区域”进行数据处理. 原表: 执行分组查询: select G ...

  6. TCP之单项通信

    TestServer.java package com.sxt.tcp; /* * 服务端 */ import java.io.DataInputStream; import java.io.IOEx ...

  7. ROS通过图形化界面控制和查看小乌龟参数

    ROS图形化界面能够让我们快速开发ROS,也有利于我们观测数据. 下面介绍一下利用图形化界面控制小乌龟按照指令行进和查看小乌龟的行进参数. 首先我们需要做一些准备工作: 在Terminal中运行以下命 ...

  8. WPS修订功能的使用

    WPS设置 设置用户名: 修改之后的效果:

  9. hdu 5793 A Boring Question(2016第六场多校)

    A Boring Question Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others ...

  10. day6_python之json序列化和反序列化

    json作用:用来保存当前状态 1.使用json.dumps序列化把dic字典存到文件中 dic={'name':'egon','age':18} print(json.dumps(dic)) #得到 ...