• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

vue addRoutes路由动态加载操作

vue 搞代码 4年前 (2022-01-08) 67次浏览 已收录 0个评论

这篇文章主要介绍了vue addRoutes路由动态加载操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧

需求:增加权限控制,实现不同角色显示不同的路由导航

思路:每次登陆后请求接口返回当前角色路由

核心方法: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', comp<strong style="color:transparent">本文来源gao@daima#com搞(%代@#码网@</strong>onent: () => 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

  <div class="leftnav"> <!--<div class=""> <div class="LiHeader"> {{nav.name}} </div> <li> {{item.name}} </li> </div>--> <div class="" style="width: 200px"> <div class="" style="color: #ffffff;height: 40px;line-height: 40px;padding-left: 20px;font-size: 16px"> {{nav.meta.title}} </div>{{item.meta.title}}</div></div> 

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路由动态加载操作就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持脚本之家。

您可能感兴趣的文章:

  • vue 解决addRoutes动态添加路由后刷新失效问题
  • vue-router+vuex addRoutes实现路由动态加载及菜单动态加载
  • vue addRoutes实现动态权限路由菜单的示例
  • vue用addRoutes实现动态路由的示例
  • 解决vue addRoutes不生效问题
  • vue 解决addRoutes多次添加路由重复的操作
  • Vue项目中使用addRoutes出现问题的解决方法

以上就是vue addRoutes路由动态加载操作的详细内容,更多请关注gaodaima搞代码网其它相关文章!


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:vue addRoutes路由动态加载操作

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址