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

思路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. Directx教程(27) 简单的光照模型(6)

    原文:Directx教程(27) 简单的光照模型(6)      从myTutorialD3D11_15到myTutorialD3D11_19的工程中,我们都只有一个光源,光源的位置在LightCla ...

  2. 2019-8-30-C#-从零开始写-SharpDx-应用-笔刷

    title author date CreateTime categories C# 从零开始写 SharpDx 应用 笔刷 lindexi 2019-8-30 8:50:0 +0800 2019-6 ...

  3. PLAY2.6-SCALA(八) comet

    Comet是指基于 HTTP 长连接的“服务器推”技术,是一种不需要客户端主动请求,服务端可以主动给客户端推送消息的技术. 1.使用chunked response来实现Comet chunked r ...

  4. MacOS局域网访问Windows7共享文件

    配置步骤 Windows7 进入[控制面板]-[网络和共享中心]-[高级共享设置] 启用网络发现 启用文件和打印机共享 选择要共享的文件或文件夹,点击[共享]-[特定用户] 选择Windows7当前登 ...

  5. 【JZOJ4859】【NOIP2016提高A组集训第7场11.4】连锁店

    题目描述 Dpstr开了个饮料连锁店,连锁店共有n家,出售的饮料种类相同.为了促销,Dpstr决定让每家连锁店开展赠送活动.具体来说,在第i家店,顾客可以用ai个饮料瓶兑换到bi瓶饮料和1个纪念币(注 ...

  6. Python中的简单实现UDP协议没有粘包问题

    服务端: import socket server=socket.socket(socket.AF_INET,socket.SOCK_DGRAM) #数据报协议->udp server.bind ...

  7. 关于编码的发展演变:ASCII、GB2312、GBK、gb18030、Unicode、UTF-8

    [1]ASCII 每个字符占据1bytes(字节),第一次以规范标准发表是在1967年,最后一次修订是在1986年.用二进制表示的话最高位必须为0(扩展的ASCII不在考虑范围内),因此ASCII只能 ...

  8. oralce ROLLUP

    select id,area,stu_type,sum(score) score from students group by rollup(id,area,stu_type) order by id ...

  9. @codechef - MXMN@ Maximum and Minimum

    目录 @description@ @solution@ @accepted code@ @details@ @description@ 定义函数 f(G, x, y) 为 G 中点 x 和点 y 之间 ...

  10. HZOJ 通讯

    B. 通讯 题目描述 “这一切都是命运石之门的选择.” 试图研制时间机器的机关SERN截获了中二科学家伦太郎发往过去的一条短 信,并由此得知了伦太郎制作出了电话微波炉(仮). 为了掌握时间机器的技术, ...