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 写类方式之八
Jul 05 Javascript
js中关于new Object时传参的一些细节分析
Mar 13 Javascript
IE6-IE9不支持table.innerHTML的解决方法分享
Sep 14 Javascript
返回上一页并自动刷新的JavaScript代码
Feb 19 Javascript
jQuery实现的图片分组切换焦点图插件
Jan 06 Javascript
JavaScript监听文本框回车事件并过滤文本框空格的方法
Apr 16 Javascript
详解BootStrap中Affix控件的使用及保持布局的美观的方法
Jul 08 Javascript
AngularJS基础 ng-selected 指令简单示例
Aug 03 Javascript
JS简单获取日期相差天数的方法
Apr 24 Javascript
vue.js国际化 vue-i18n插件的使用详解
Jul 07 Javascript
使用Javascript简单计算器
Nov 17 Javascript
Vee-validate 父组件获取子组件表单校验结果的实例代码
May 20 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与java通过socket通信的实现代码
2013/10/21 PHP
让CodeIgniter的ellipsize()支持中文截断的方法
2014/06/12 PHP
PHP的Socket通信之UDP通信实例
2015/07/02 PHP
iOS自定义提示弹出框实现类似UIAlertView的效果
2016/11/16 PHP
PHP获取页面执行时间的方法(推荐)
2016/12/10 PHP
php从身份证获取性别和出生年月
2017/02/09 PHP
Laravel中10个有用的用法小结
2019/05/06 PHP
理解Javascript_03_javascript全局观
2010/10/11 Javascript
Js实现双击鼠标自动滚动屏幕的示例代码
2013/12/14 Javascript
jQuery的3种请求方式$.post,$.get,$.getJSON
2014/03/28 Javascript
javascript移动设备Web开发中对touch事件的封装实例
2014/06/05 Javascript
jQuery实现带渐显效果的人物多级关系图代码
2015/10/16 Javascript
javascript拖拽应用实例
2016/03/25 Javascript
简单实现JS倒计时效果
2016/12/23 Javascript
angularjs利用directive实现移动端自定义软键盘的示例
2017/09/20 Javascript
jQuery zTree搜索-关键字查询 递归无限层功能实现代码
2018/01/25 jQuery
Spring Boot/VUE中路由传递参数的实现代码
2018/03/02 Javascript
让你5分钟掌握9个JavaScript小技巧
2018/06/09 Javascript
vuejs实现ready函数加载完之后执行某个函数的方法
2018/08/31 Javascript
js神秘的电报密码 哈弗曼编码实现
2019/09/10 Javascript
vue视频播放插件vue-video-player的具体使用方法
2019/11/08 Javascript
vue keep-alive列表页缓存 详情页返回上一页不刷新,定位到之前位置
2019/11/26 Javascript
Vue中import from的来源及省略后缀与加载文件夹问题
2020/02/09 Javascript
一些Python中的二维数组的操作方法
2015/05/02 Python
用Python写一个无界面的2048小游戏
2016/05/24 Python
sublime text 3配置使用python操作方法
2017/06/11 Python
Python实现修改文件内容的方法分析
2018/03/25 Python
英国屋顶用品和材料超市:Roofing Supplies UK
2019/08/24 全球购物
新加坡一家在线男士皮具品牌:Faire Leather Co.
2019/12/01 全球购物
自荐信如何“自荐”
2013/10/24 职场文书
《童年的发现》教学反思
2014/02/14 职场文书
2015个人半年总结范文
2015/03/09 职场文书
2015年财务个人工作总结范文
2015/05/22 职场文书
Python - 10行代码集2000张美女图
2021/05/23 Python
防止web项目中的SQL注入
2021/12/06 MySQL
MySQL表字段数量限制及行大小限制详情
2022/07/23 MySQL