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 相关文章推荐
总结AJAX相关JS代码片段和浏览器模型
Aug 15 Javascript
IE的fireEvent方法概述及应用
Feb 22 Javascript
jquery checkbox实现单选小例
Nov 27 Javascript
js控制href内容的连接内容的变化示例
Apr 30 Javascript
深入理解javascript中的立即执行函数(function(){…})()
Jun 12 Javascript
jQuery中get()方法用法实例
Dec 27 Javascript
JavaScript设置表单上传时文件个数的方法
Aug 11 Javascript
JQuery控制DIV的选取实现方法
Sep 18 Javascript
JS+HTML5实现的前端购物车功能插件实例【附demo源码下载】
Oct 17 Javascript
详解vue-cli下ESlint 配置说明
Sep 03 Javascript
js监听html页面的上下滚动事件方法
Sep 11 Javascript
JS获取月的第几周和年的第几周实例代码
Dec 05 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 max_execution_time执行时间问题
2011/07/17 PHP
php中的静态变量的基本用法
2014/03/20 PHP
PHP错误WARNING: SESSION_START() [FUNCTION.SESSION-START]解决方法
2014/05/04 PHP
thinkphp3.2点击刷新生成验证码
2016/02/16 PHP
宝塔面板在NGINX环境中TP5.1如何运行?
2021/03/09 PHP
JavaScript 编程引入命名空间的方法
2007/06/29 Javascript
用JavaScript获取DOM元素位置和尺寸大小的方法
2013/04/12 Javascript
Google Map V3 绑定气泡窗口(infowindow)Dom事件实现代码
2013/04/26 Javascript
5个可以帮你理解JavaScript核心闭包和作用域的小例子
2014/10/08 Javascript
js获取会话框prompt的返回值的方法
2015/01/10 Javascript
js中的事件捕捉模型与冒泡模型实例分析
2015/01/10 Javascript
关于动态执行代码(js的Eval)实例详解
2016/08/15 Javascript
Javascript 判断两个IP是否在同一网段实例代码
2016/11/28 Javascript
jQuery中ajax错误调试分析
2016/12/01 Javascript
js date 格式化
2017/02/15 Javascript
基于js中的原型(全面讲解)
2017/09/19 Javascript
vue实现页面加载动画效果
2017/09/19 Javascript
JavaScript html5 canvas实现图片上画超链接
2017/10/20 Javascript
vue获取当前点击的元素并传值的实例
2018/03/09 Javascript
小程序二次贝塞尔曲线实现购物车商品曲线飞入效果
2019/01/07 Javascript
记一次用ts+vuecli4重构项目的实现
2020/05/21 Javascript
c++生成dll使用python调用dll的方法
2014/01/20 Python
python读写二进制文件的方法
2015/05/09 Python
python图像处理之镜像实现方法
2015/05/30 Python
python制作企业邮箱的爆破脚本
2016/10/05 Python
matplotlib绘制动画代码示例
2018/01/02 Python
Django重置migrations文件的方法步骤
2019/05/01 Python
python中如何设置代码自动提示
2020/07/15 Python
html5组织内容_动力节点Java学院整理
2017/07/10 HTML / CSS
加拿大知名的国际儿童品牌:Hatley
2016/11/09 全球购物
Lou & Grey美国官网:主打舒适性面料服饰
2017/12/21 全球购物
依法行政工作汇报
2014/10/28 职场文书
武侯祠导游词
2015/02/04 职场文书
行政人事专员岗位职责
2015/04/07 职场文书
工作会议通知
2015/04/15 职场文书
Python matplotlib绘制条形统计图 处理多个实验多组观测值
2022/04/21 Python