DDR爱好者之家 Design By 杰米
需求:增加权限控制,实现不同角色显示不同的路由导航
思路:每次登陆后请求接口返回当前角色路由
核心方法:vue-router2.2.0的addRoutes方法 + vuex
以下是我实现的获取菜单路由的方法,我将该方法的调用放在首页组件的生命钩子中,即便用户刷新浏览器清空了路由还是会重新调用接口获取,不至于会丢失。同时考虑到会有切换用户的可能,所以不将获取到的路由信息保存到cookie或者localstorage当中
获取菜单之前先判断routerState,避免多次请求, 我这里使用element-ui的导航菜单功能v-for循环this.myRouter参数即可显示动态路由导航
/** * 获取菜单 */ getMenu () { if (this.$store.getters.routerState === false) { // 清理已经存在的动态路由 this.clearDynamicRoute() // 更改请求路由状态为true this.$store.commit('SET_ROUTERSTATE', true) getMyMenu().then((res) => { if (res.code === '0') { // 格式化路由,将数据转为addRoutes可接受的route格式数组 let myMenu = this.formatMenu(res.data.menu) if (myMenu.length <= 0) { // 没有动态路由 return } for (let index = 0; index < myMenu.length; index++) { // 将请求的路由先存放到options对象中 this.$router.options.routes.push(myMenu[index]) } // 将完整需要显示的路由添加进去 this.$router.addRoutes(this.$router.options.routes) // 这里将路由显示在页面上 this.MyRouter = this.$router.options.routes } // 在这里就可以打印出新路由 console.log(this.$router) }) } }
补充知识:vue+element 进入不同路由页面(二级页面),让相应的左侧菜单
路由配置
{ path: '/finance', name: 'Finance', meta: { title: '财务' }, component: () => import('@/components/Finance'), redirect: '/finance/code/code', children: [{ path: '/finance/code', name: 'financeindex', meta: { title: '税收配置' }, redirect: '/finance/code/code', component: () => import('@/components/finance/financeindex'), children: [{ path: '/finance/code/code', name: 'FinanceCode', hidden: false, active:'/finance/code', //这里是在左侧菜单显示并且需要选中的 meta: { title: '税收编码(金税)' }, component: () => import('@/components/finance/code/Code'), }, { path: '/finance/code/codeimportrecord', // 这个路由进入的界面是 税收编码(金税)的二级页面, 当进入这个页面的时候,需要菜单中的税收编码(金税)显示选中 name: 'FinanceCodeImportRecord', hidden: true, meta: { title: '税收编码导入记录' }, component: () => import('@/components/finance/code/CodeImportRecord'), }, { path: '/finance/classcode/classcode', name: 'FinanceClassCode', hidden: false, active:'/finance/classcode', //为了省事,只给需要在左侧显示的路由添加active属性 meta: { title: '分类税收编码确认' }, component: () => import('@/components/finance/classCode/ClassCode'), }, ] }, ]
element
<template> <div class="leftnav"> <!--<div class="" v-for="nav in navs"> <div class="LiHeader"> {{nav.name}} </div> <li v-for="item in nav.san"> {{item.name}} </li> </div>--> <el-menu style="text-align: left;" :default-active=this.show // 这是的值是指与 el-menu-item中:index的值对应的那一天显示选中(正常情况就是一个页面一个路由,进入那个路由,对应的导航菜单需要选中) class="el-menu-vertical-demo" @open="handleOpen" @close="handleClose" background-color="#282b33" text-color="#bcbcbc" active-text-color="#ffffff"> <div class="" v-for="(nav,index) in navs" :key="index" style="width: 200px;"> <div class="" style="color: #ffffff;height: 40px;line-height: 40px;padding-left: 20px;font-size: 16px;"> {{nav.meta.title}} </div> <el-menu-item @click="clickroute(item.path)" v-for="(item,index) in nav.children" v-if="!item.hidden" :key="index" :index="item.active"(这里原来是item.path) style="height: 40px;line-height: 40px;">{{item.meta.title}}</el-menu-item> </div> </el-menu> </div> </template> <script>
js
data() { return { navs:[], show:null //初始化上面:default-active绑定的值 } }, created() { //// 页面载入的时候,拿到url,用/拆开,然后拼起来前两个路径,并且赋值, 这个时候show对应的就是路由表中的 avtive, let route=this.$route.path.split('/') let vueRouter=this.$router.options.routes.filter(router=>{return router.path=='/'})[0].children let filterVuerouter=vueRouter.filter(router=>{return '/'+route[1] == router.path }) this.navs=filterVuerouter[0].children console.log(this.navs) let router ='/'+route[1]+'/'+route[2] console.log(router) this.show=router // console.log(this.show) }, mounted() { },
以上这篇vue addRoutes路由动态加载操作就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
DDR爱好者之家 Design By 杰米
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
DDR爱好者之家 Design By 杰米
暂无评论...
更新日志
2024年11月15日
2024年11月15日
- 群星-时尚慢摇DJ舞曲《发烧车载中文天碟-调情》非卖品[WAV]
- 潘美辰.2008-全新重声大碟(出道20年精选纪念版)【倍特音乐】【WAV+CUE】
- 罗时丰.2002-唱歌的人(2011再生版)【贝特音乐】【WAV+CUE】
- 罗时丰.2003-唱歌的人台语精选+新歌【贝特音乐】【WAV+CUE】
- 999PUNKSTA《情绪数码故障》[Hi-Res][24bit 48kHz][FLAC/分轨][301.83MB]
- HOYO-MiX《原神-珍珠之歌4 游戏音乐》[320K/MP3][289.48MB]
- 陈崎凡《CHEN》[320K/MP3][81.13MB]
- skt都在哪一年夺冠 英雄联盟skt夺冠赛季介绍
- 炉石传说抢先体验乱斗什么时候结束 深暗领域体验乱斗结束时间
- 炉石传说抢先乱斗卡组有什么 深暗领域抢先体验乱斗卡组推荐
- 荣耀手机腕上最佳搭档 荣耀手表5首销开启
- 雷克沙ARES 6000 C28战神之翼 AMD 9800X3D超强搭档
- 咪咕快游感恩同游,超值回馈尽在咪咕咪粉节!
- 陈崎凡《CHEN》[FLAC/分轨][326.32MB]
- 群星《我们的歌第六季 第2期》[320K/MP3][74.05MB]