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 相关文章推荐
JS代码格式化和语法着色V2
Oct 14 Javascript
添加JavaScript重载函数的辅助方法2
Jul 04 Javascript
JavaScript判断变量是否为undefined的两种写法区别
Dec 04 Javascript
javascript html实现网页版日历代码
Mar 08 Javascript
JS实现漂亮的时间选择框效果
Aug 20 Javascript
jQuery simpleModal插件的使用介绍
Aug 30 Javascript
浅谈AngularJS中ng-class的使用方法
Nov 11 Javascript
详解vue表单——小白速看
Apr 08 Javascript
bootstrap下拉分页样式 带跳转页码
Dec 29 Javascript
微信小程序云开发之使用云数据库
May 17 Javascript
Vue.js 无限滚动列表性能优化方案
Dec 02 Javascript
javascript实现超好看的3D烟花特效
Jan 01 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高级对象构建 工厂模式的使用
2012/02/05 PHP
PHP PDO和消息队列的个人理解与应用实例分析
2019/11/25 PHP
jQuery的实现原理的模拟代码 -4 重要的扩展函数 extend
2010/08/03 Javascript
动态加载图片路径 保持JavaScript控件的相对独立性
2010/09/03 Javascript
JS分割字符串并放入数组的函数
2011/07/04 Javascript
js定时器怎么写?就是在特定时间执行某段程序
2013/10/11 Javascript
jQuery插件Zclip实现完美兼容个浏览器点击复制内容到剪贴板
2015/04/30 Javascript
jQuery实现Tab菜单滚动切换的方法
2015/09/21 Javascript
给easyui datebox扩展一个清空的实例
2016/11/09 Javascript
JS中使用new Date(str)创建时间对象不兼容firefox和ie的解决方法(两种)
2016/12/14 Javascript
AngularJS动态添加数据并删除的实例
2018/02/27 Javascript
Vue实现动态创建和删除数据的方法
2018/03/17 Javascript
详解easyui基于 layui.laydate日期扩展组件
2018/07/18 Javascript
Vue使用lodop实现打印小结
2019/07/06 Javascript
详解JavaScript 的执行机制
2020/09/18 Javascript
python查找指定具有相同内容文件的方法
2015/06/28 Python
详解使用 pyenv 管理多个版本 python 环境
2017/10/19 Python
python正则-re的用法详解
2019/07/28 Python
对于Python深浅拷贝的理解
2019/07/29 Python
Python帮你识破双11的套路
2019/11/11 Python
如何使用python3获取当前路径及os.path.dirname的使用
2019/12/13 Python
Tensorflow--取tensorf指定列的操作方式
2020/06/30 Python
CSS3条纹背景制作的实战攻略
2016/05/31 HTML / CSS
Html5实现用户注册自动校验功能实例代码
2016/05/24 HTML / CSS
加热夹克:RAVEAN
2018/10/19 全球购物
Raffaello Network西班牙:意大利拉斐尔时尚购物网
2019/03/12 全球购物
生产内勤岗位职责
2013/12/07 职场文书
工程造价专业大学生职业规划范文
2014/03/09 职场文书
有关环保的标语
2014/06/13 职场文书
政风行风评议心得体会
2014/10/21 职场文书
2015年世界水日活动总结
2015/02/09 职场文书
导游词400字
2015/02/13 职场文书
解决vue $http的get和post请求跨域问题
2021/06/07 Vue.js
Win11开始菜单添加休眠选项
2022/04/19 数码科技
MySQL主从切换的超详细步骤
2022/06/28 MySQL