vue权限控制菜单显示的简单实现
为了对于不同角色显示不同的菜单
思路1:
本地放一份完整的菜单数据,通过后台返回角色的菜单列表.两者对比,筛选需要显示的菜单数据绑定,
这里有个问题就是路由vue实例初始化就生成了,加载的全部,人为输入地址是可以访问到角色权限以外的数据,
所以还要加路由构子router.beforeEach()去做判断哪些是角色权限以内的路由.
这种思路的比较复杂,逻辑比较多
思路2:
Vue Router官方API:

利用router.addRouter()就可以动态添加路由实现
下面详细讲一讲vue.addRouter()实现步骤
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()触发
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/>'
})
具体源码请访问https://github.com/liuyangjike/dynamic-router 一个实现的demo,如果觉得有帮助,请star一下
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这类双向绑定框架做后台系统再适合不过,后台系统相比普通 ...
- yii2 rbac权限控制之菜单menu详细教程
作者:白狼 出处:http://www.manks.top/article/yii2_rbac_menu本文版权归作者,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则 ...
- yii2权限控制rbac之菜单menu最详细教程
前面我们在博文 yii2搭建完美后台并实现rbac权限控制实例教程中完美实现了yii2的后台搭建和rbac权限控制,如果你还没有实现,请先看上文再回来参考本文,因为本文是在上文的基础上进行完善和补充. ...
- vue中如何实现后台管理系统的权限控制
vuejs单页应用的权限管理实践 一.前言 在广告机项目中,角色的权限管理是卡了挺久的一个难点.首先我们确定的权限控制分为两大部分,其中根据粒的大小分的更细: 接口访问的权限控制 页面的权限控制 菜单 ...
- vue项目权限控制
Vue权限控制有各种方法,大概分为两个方向: 把当前角色对应的权限保存在浏览器本地(容易被恶意修改): 将操作权限保存在vuex中(推荐此种方式:页面一刷新就没了,可以再次向后端请求相关数据,始终保持 ...
- vue-quasar-admin 一个包含通用权限控制的后台管理系统
vue-quasar-admin Quasar-Framework 是一款基于vue.js开发的开源的前端框架, 它能帮助web开发者快速创建以下网站:响应式网站,渐进式应用,手机应用(通过Cor ...
随机推荐
- tomcat7 bootstrap
tomcat7 bootstrap http://t5crambing.iteye.com/blog/1923636
- [Python] String Join
Let's introduce a new string method, join: >>> nautical_directions = "\n".join([& ...
- 73.node.js开发错误——TypeError: Cannot set property 'XXX' of undefined
转自:https://blog.csdn.net/fd214333890/article/details/53467429
- vue 引入第三方字体包
1.创建 style_css 文件夹,在当前文件夹下 新建 index.css 和 引入字体包. 2. 在build 目录下,设置 webpack.base.cong.js , 在module ...
- Stacked Autoencoders
转自:http://www.cnblogs.com/tornadomeet/archive/2013/03/25/2980357.html 如果使用多层神经网络的话,那么将可以得到对输入更复杂的函数表 ...
- C# 正整数和非零正整数校验
/// <summary> /// 1. 校验正整数(包含0) /// </summary> public static bool isInterger(string str) ...
- 【2017 Multi-University Training Contest - Team 3】Kanade's sum
[Link]:http://acm.hdu.edu.cn/showproblem.php?pid=6058 [Description] 给你n个数; 它们是由(1..n)组成的排列; 然后给你一个数字 ...
- Spring AOP那些学术概念—通知、增强处理连接点(JoinPoint)切面(Aspect)(转)
1.我所知道的AOP 初看起来,上来就是一大堆的术语,而且还有个拉风的名字,面向切面编程,都说是OOP的一种有益补充等等.一下让你不知所措,心想着:管不得很多人都和我说AOP多难多难.当我看进去以后, ...
- [React] Use a Render Porp
More detail check LInk. Render Prop vs HOC: HOC version for withMouse: import React from 'react' imp ...
- artDialog提示框、对话框
/** * 警告 * @param {String}消息内容 */ artDialog.alert = function (content, callback) { return artDialog( ...