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实现字符串反转的方法
Feb 05 Javascript
JavaScript中的splice()方法使用详解
Jun 09 Javascript
JavaScript的MVVM库Vue.js入门学习笔记
May 03 Javascript
基于jQuery的AJAX和JSON实现纯html数据模板
Aug 09 Javascript
详谈Ajax请求中的async:false/true的作用(ajax 在外部调用问题)
Feb 10 Javascript
Angular使用Md5加密的解决方法
Sep 16 Javascript
javascript实现电脑和手机版样式切换
Nov 10 Javascript
JS简单生成由字母数字组合随机字符串示例
May 25 Javascript
JS实现选项卡效果的代码实例
May 20 Javascript
vue中npm包全局安装和局部安装过程
Sep 03 Javascript
使用React-Router实现前端路由鉴权的示例代码
Jul 26 Javascript
详解ES6实现类的私有变量的几种写法
Feb 10 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
我的论坛源代码(四)
2006/10/09 PHP
php执行sql语句的写法
2009/03/10 PHP
php利用cookie实现自动登录的方法
2014/12/10 PHP
Array对象方法参考
2006/10/03 Javascript
jquery 倒计时效果实现秒杀思路
2013/09/11 Javascript
js 页面元素的几个用法总结
2013/11/18 Javascript
Mac/Windows下如何安装Node.js
2013/11/22 Javascript
js控制容器隐藏出现防止样式变化的两种方法
2014/04/25 Javascript
JS获取各种宽度、高度的简单介绍
2014/12/19 Javascript
jquery插件jquery.beforeafter.js实现左右拖拽分隔条对比图片的方法
2015/08/07 Javascript
一步步教大家编写酷炫的导航栏js+css实现
2016/03/14 Javascript
JS+HTML5实现的前端购物车功能插件实例【附demo源码下载】
2016/10/17 Javascript
ES6使用let命令更简单的实现块级作用域实例分析
2017/03/31 Javascript
HTML5实现微信拍摄上传照片功能
2017/04/21 Javascript
JavaScript寄生组合式继承实例详解
2018/01/06 Javascript
vue-cli项目优化方法- 缩短首屏加载时间
2018/04/01 Javascript
js prototype和__proto__的关系是什么
2019/08/23 Javascript
js中的面向对象之对象常见创建方法详解
2019/12/16 Javascript
浅谈Vue static 静态资源路径 和 style问题
2020/11/07 Javascript
[01:58]2018DOTA2亚洲邀请赛趣味视频——交流
2018/04/03 DOTA
pymssql数据库操作MSSQL2005实例分析
2015/05/25 Python
python difflib模块示例讲解
2017/09/13 Python
Python3 循环语句(for、while、break、range等)
2017/11/20 Python
基于python神经卷积网络的人脸识别
2018/05/24 Python
让你Python到很爽的加速递归函数的装饰器
2019/05/26 Python
Python计算公交发车时间的完整代码
2020/02/12 Python
Python异常继承关系和自定义异常实现代码实例
2020/02/20 Python
Python unittest工作原理和使用过程解析
2020/02/24 Python
pycharm2020.1.2永久破解激活教程,实测有效
2020/10/29 Python
一套英文Java笔试题面试题
2016/04/21 面试题
机电专业毕业生求职信
2013/10/27 职场文书
物业门卫岗位职责
2013/12/28 职场文书
2014年中学生检讨书大全
2014/10/09 职场文书
小学语文国培研修日志
2015/11/13 职场文书
python中if和elif的区别介绍
2021/11/07 Python
redis lua限流算法实现示例
2022/07/15 Redis