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 ...
随机推荐
- li设置多选和取消选择的样式、输入数据类型判断
li设置多选和取消选择的样式: $('li').click(function(){ if($(this).hasClass('active')) {$(this).removeClass('activ ...
- 基于OPNET的路由协议仿真教程(AODV、OLSR 、DSR等)
前言: 目前由于项目需要,学习了基于opnet的网络仿真方法,发现该软件的学习资料少之又少,所以将自己搜集到的学习资料进行整理,希望能帮助后来的人. 主要参考资料:OPNET网络仿真(清华陈敏版) 仿 ...
- Codeforces 336C
这题是大一暑假时候做的,当时没有出,直到今天突然觉得应该把没过的题目再做一边,不然真的是越积越多. 现在能够独立做出来真的是难以表达的兴奋,刚开始的时候就觉得 O(30 * 30 * n)的复杂度有点 ...
- Kubernetes1.3新特性:支持GPU
(一) 背景资料 GPU就是图形处理器,是Graphics Processing Unit的缩写.电脑显示器上显示的图像,在显示在显示器上之前,要经过一些列处理,这个过程有个专有的名词叫" ...
- Introduction to 3D Game Programming with DirectX 12 学习笔记之 --- 第十一章:模板测试
原文:Introduction to 3D Game Programming with DirectX 12 学习笔记之 --- 第十一章:模板测试 代码工程地址: https://github.co ...
- Java练习 SDUT-3081_谁是最强女汉子
谁是最强的女汉子 Time Limit: 1000 ms Memory Limit: 65536 KiB Problem Description 众所周知,一年一度的女汉子大赛又来啦.由于最近女汉子比 ...
- AtCoder Grand Contest 019 B - Reverse and Compare【思维】
AtCoder Grand Contest 019 B - Reverse and Compare 题意:给定字符串,可以选定任意i.j且i<=j(当然i==j时没啥卵用),然后翻转i到j的字符 ...
- 通过反射拿到构造方法 Day25
package com.sxt.constructor; /* * 反射 * Class类拿到构造方法 */ import java.lang.reflect.Constructor; public ...
- 如何创建一个非常酷的3D效果菜单
http://www.cocoachina.com/ios/20150603/11992.html 原文地址在这里.原文 去年,读者们投票选出了Top5的iOS7最佳动画,当然也很想看到有关这些动画如 ...
- 修改UISearchBar背景
转载:http://blog.csdn.net/favormm/archive/2010/11/30/6045463.aspx UISearchBar是由两个subView组成的,一个是UISearc ...