vue 解决addRoutes多次添加路由重复的操作


Posted in Javascript onAugust 04, 2020

我就废话不多说了,大家还是直接看代码吧~

import Vue from 'vue'
import Router from 'vue-router'
Vue.use(Router)

const createRouter = () => new Router({
 mode: 'history',
 routes: []
})

const router = createRouter()

export function resetRouter () {
 const newRouter = createRouter()
 router.matcher = newRouter.matcher // the relevant part
}

export default router

找老外的文档解决的问题,在登出的模块调用resetRouter方法,把原来的路由替换。

补充知识:vue中 做权限管理 使用router.addRoutes()动态添加路由以及解决刷新失效,跳转后刷新失效问题

最近在公司做知识储备,有个权限的问题干扰了我2天,今天终于把他理顺了!!!

一、需求明确

我想做的是后台管理系统的权限管理,(所有的数据都是使用mockJs模拟得来),登录的时候,发送表单验证,验证成功后,后台返回权限列表,权限不同,返回的列表不同,拿到权限列表后,把权限列表渲染出来在页面侧边栏上。

二、注意点

(1) 前端提前设置静态的权限列表,通常只包括页面公共的部分,比如 login。

(2)前端提前定义所有的权限列表,将其定义为一个数组,该数组中包含所有的权限。

(3)后台返回的数据是该用户拥有的所有权限列表,一般写成路由形式,但只包含name即可,如:

{
  "code": 0,
  "message": "获取权限成功",
  "data": [
    {
      "name": "订单管理",
      "children": [
        {
          "name": "订单列表"
        },
        {
          "name": "生产管理",
          "children": [
            {
              "name": "生产列表"
            }           
          ]
        },
        {
          "name": "退货管理"
        }
      ]
    }
  ]
}

三、思路与实现

(1)当用户点击登录的时候,验证成功后,可以获取当前用户的id(token)存储到sessionStorage中。

(2)根据 '后台返回的权限列表(getList)',去比对 '我们提前定义好的权限列表(powerList)',然后得出 '应该动态添加的权限列表(list)' ,并存放到vuex中,最后执行addRoutes把比对出来的权限路由列表动态添加到路由中即可。

(3)进入home页面,渲染侧边栏。

四、问题

(1)vuex中数据存储在内存中,刷新后失效需要重新获取。因此会出现动态页面失效问题。我们需要根据是否为刷新页面来重新加载即可。

(2)进入动态加载的页面,然后再刷新,也会出现上面的情况

五、解决方法

在router的全局导航守卫beforeEach中设置,根据vuex中是否有list 来判断是否为刷新页面,如果有那么是第一次登陆, 如果没有,那么就为刷新页面,需要重新执行即可。

vue 解决addRoutes多次添加路由重复的操作

getRoutes就是执行路由对比,然后执行addRoutes的函数,因为其中有获取后台的路由列表这一步,为异步操作,所以应该放在action中

以上这篇vue 解决addRoutes多次添加路由重复的操作就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
javascript跑马灯悬停放大效果实现代码
Dec 12 Javascript
使用DeviceOne实现微信小程序功能
Dec 29 Javascript
详解React开发中使用require.ensure()按需加载ES6组件
May 12 Javascript
在bootstrap中实现轮播图实例代码
Jun 11 Javascript
underscore之function_动力节点Java学院整理
Jul 11 Javascript
深入理解angular2启动项目步骤
Jul 15 Javascript
基于Vue实例生命周期(全面解析)
Aug 16 Javascript
Es6 Generator函数详细解析
Feb 24 Javascript
详解IOS微信上Vue单页面应用JSSDK签名失败解决方案
Nov 14 Javascript
vue+Element-ui实现分页效果实例代码详解
Dec 10 Javascript
Vue 幸运大转盘实现思路详解
May 06 Javascript
JS数组方法slice()用法实例分析
Jan 18 Javascript
Vue优化:常见会导致内存泄漏问题及优化详解
Aug 04 #Javascript
Jquery cookie插件实现原理代码解析
Aug 04 #jQuery
解决vue自定义指令导致的内存泄漏问题
Aug 04 #Javascript
vue中的v-model原理,与组件自定义v-model详解
Aug 04 #Javascript
详解JS深拷贝与浅拷贝
Aug 04 #Javascript
vue addRoutes路由动态加载操作
Aug 04 #Javascript
vue+element使用动态加载路由方式实现三级菜单页面显示的操作
Aug 04 #Javascript
You might like
php中关于codeigniter的xmlrpc的类在进行数据交换时的类型问题
2011/07/03 PHP
php面向对象 字段的声明与使用
2012/06/14 PHP
laravel 5 实现模板主题功能
2015/03/02 PHP
thinkPHP5.0框架安装教程
2017/03/25 PHP
PHP 计算两个时间段之间交集的天数示例
2019/10/24 PHP
JQuery 获得绝对,相对位置的坐标方法
2010/02/09 Javascript
使用jQuery动态加载js脚本文件的方法
2014/04/03 Javascript
jQuery获取样式中颜色值的方法
2015/01/29 Javascript
javascript通过获取html标签属性class实现多选项卡的方法
2015/07/27 Javascript
JS实现常见的TAB、弹出层效果(TAB标签,斑马线,遮罩层等)
2015/10/08 Javascript
深入分析jQuery的ready函数是如何工作的(工作原理)
2015/12/17 Javascript
jquery实现点击其他区域时隐藏下拉div和遮罩层的方法
2015/12/23 Javascript
JavaScript结合Bootstrap仿微信后台多图文界面管理
2016/07/22 Javascript
用jquery获取自定义的标签属性的值简单实例
2016/09/17 Javascript
Bootstrap Img 图片样式(推荐)
2016/12/13 Javascript
Node使用Sequlize连接Mysql报错:Access denied for user ‘xxx’@‘localhost’
2018/01/03 Javascript
详解如何为你的angular app构建一个第三方库
2018/12/07 Javascript
小程序数据通信方法大全(推荐)
2019/04/15 Javascript
Vue安装浏览器开发工具的步骤详解
2019/05/12 Javascript
24个解决实际问题的ES6代码片段(小结)
2020/02/02 Javascript
Node.js API详解之 Error模块用法实例分析
2020/05/14 Javascript
Nest.js 授权验证的方法示例
2021/02/22 Javascript
[01:07]2015国际邀请赛 中国区预选赛精彩回顾
2015/06/15 DOTA
python中numpy包使用教程之数组和相关操作详解
2017/07/30 Python
Python数据结构之单链表详解
2017/09/12 Python
Python While循环语句实例演示及原理解析
2020/01/03 Python
Flask和pyecharts实现动态数据可视化
2020/02/26 Python
结合CSS3的布局新特征谈谈常见布局方法
2016/01/22 HTML / CSS
德购商城:德国进口直邮商城
2017/06/13 全球购物
联想法国官方网站:Lenovo法国
2018/10/18 全球购物
ZINVO手表官网:男士和女士手表
2019/03/10 全球购物
信号量和自旋锁的区别?如何选择使用?
2015/09/08 面试题
我们没有写servlet的构造方法,那么容器是怎么创建servlet的实例呢
2013/04/24 面试题
运动会邀请函范文
2014/01/31 职场文书
使用pandas模块实现数据的标准化操作
2021/05/14 Python
springboot+WebMagic+MyBatis爬虫框架的使用
2021/08/07 Java/Android