addroutes和next()导致的页面无法跳转问题,如登录之后无法跳转到首页,无法重定向,使用next(to)

news2024/9/20 23:30:09

版本 vue router 3

问题说明

登录成功后,想重定向到/index,执行router.push之后进入beforeEach
由于第一次访问,判断用户信息为空,需要异步拉取用户的权限等信息,
获得响应后,使用addRoutes批量添加路由信息,然后执行next()放行。

但是,页面没有跳转首页,无任何反应
控制台打印日志,没有发现问题:
在这里插入图片描述

问题分析

首先,/index路由是在本地添加的静态路由,所以总是能匹配到结果,和添加的动态路由没有关系,所以问题不是路由匹配失败导致的(路由匹配不到,应该显示白屏才对)

查看vue router源码,发现除了添加路由,下面还有一个if判断,修改了目标页面

src/index.js:

addRoutes (routes: Array<RouteConfig>) {
    this.matcher.addRoutes(routes)
    if (this.history.current !== START) {
      this.history.transitionTo(this.history.getCurrentLocation())
    }
  }
}

我们当前处于/login登录页面,无法跳转,所以history.current/loginSTART被定义为/
两者肯定是不相等的,于是会执行transitionTo(this.history.getCurrentLocation()),也就是路由目标被改成了当前页面,那我们就还是处在登录界面,而不是首页

问题解决

addRoutes后,不要使用next(),使用next(to),即手动的再次跳转到目标页面。
不过要注意,next(to)会再次进入beforeEach路由守卫,我们要设置判断逻辑,如果路由信息已经存在,就不再执行addRoutes,直接next()放行,才能跳转。不然会一直next(to),循环进入beforEach

同时,我们不希望之后每次刷新同一个页面,都重复插入相同的路由历史记录,可以加一个选项replace: true,使用替换模式来替换最新一条相同历史记录

if(路由信息已添加){
	// 直接放行
	next()
}
else{
	//添加动态路由信息
	addRoutes(xxx)
	// 手动跳转
	next({ ...to, replace: true })
}

参考资料https://mosuzi.com/docs/tech/vue-router-add-route-blocks-next/index.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2085574.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【C#】汉诺塔C#代码实现(递归)

1. 思路 假设总共需要移动n个盘子&#xff1a; 将A柱上的n-1个盘子借助C柱移向B柱将A柱上仅剩的最后一个盘子移向C柱将B柱上的n-1个盘子借助A柱移向C柱 2.代码 using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threa…

护眼台灯是不是智商税?全面测评松下、书客、飞利浦护眼台灯!

在当今数字化时代&#xff0c;长时间面对电子屏幕已成为日常生活的一部分&#xff0c;这对我们的视力健康构成了挑战。特别是在学习和工作的场景中&#xff0c;一款优质的护眼台灯不仅能够提供舒适的照明环境&#xff0c;还能有效减轻眼睛疲劳&#xff0c;保护视力。然而&#…

如何优雅的使用责任链模式?

如何优雅的使用责任链模式&#xff1f; 在业务开发中&#xff0c;总是会由于需要处理复杂的业务逻辑&#xff0c;从而造成开发者的代码冗余或者模块之间耦合度过高&#xff0c;那么当面对这种情况时&#xff0c;如何实现请求处理的灵活性和可维护性&#xff0c;责任链模式就可以…

短视频流量|基于SprinBoot+vue的短视频流量数据分析系统(源码+数据库+文档)

短视频流量数据分析系统 基于SprinBootvue的短视频流量数据分析系统 一、前言 二、系统设计 三、系统功能设计 5.1 系统功能模块 5.2 管理员功能模块实现 四、数据库设计 五、核心代码 六、论文参考 七、最新计算机毕设选题推荐 八、源码获取&#xff1a; 博主介绍…

免费批量Excel文件合并、拆分工具

软件介绍 下载地址&#xff1a;https://pan.quark.cn/s/ae860a4e2ccb 1.多个XLS或XLSX格式EXCEL文件合并&#xff0c;合并后可使用数据透视表进行相关操作。 2.自动合并多个EXCEL文件的第一个工作表&#xff0c;并汇总成一张表&#xff0c;可根据所有列标题需要指定需要的列。 …

【基础篇】行锁功过:怎么减少行锁对性能的影响?

定义 **MySQL 的行锁是在引擎层由各个引擎自己实现的。**但并不是所有的引擎都支持行锁&#xff0c;比如 MyISAM 引擎就不支持行锁。不支持行锁意味着并发控制只能使用表锁&#xff0c;对于这种引擎的表&#xff0c;同一张表上任何时刻只能有一个更新在执行&#xff0c;这就会…

一文详解JNPF低代码平台在不同行业的应用分析

随着信息技术的飞速发展&#xff0c;企业对于快速开发和部署业务应用的需求日益增长。低代码平台作为加速企业数字化转型的利器&#xff0c;正受到越来越多的关注。JNPF作为一款先进的低代码开发平台&#xff0c;凭借其强大的功能和灵活性&#xff0c;在不同行业中得到了广泛的…

Jenkins安装使用详解,jenkins实现企业级CICD流程

文章目录 一、资料1、官方文档 二、环境准备1、安装jdk172、安装maven3、安装git4、安装gitlab5、准备我们的springboot项目6、安装jenkins7、安装docker8、安装k8s&#xff08;可选&#xff0c;部署节点&#xff09;9、安装Harbor10、准备带有jdk环境的基础镜像 三、jenkins实…

禁止文件外发 | 如何禁止员工外发文件?严守企业机密,禁止员工外发敏感文件!

近期&#xff0c;我们注意到一些敏感项目资料有外泄的风险&#xff0c;这对公司的核心竞争力构成了严重威胁&#xff01; 我们必须立即采取行动&#xff0c;严守企业机密&#xff0c;确保每一份文件都安全无虞。 从今天起&#xff0c;我们要全面升级信息安全措施&#xff0c;…

Java基础(5)- Java代码笔记2

目录 一、键盘录入_Scanner 1.输入&#xff1a;导包 -> 创建对象 -> 调用方法 2.next和nextLine区别 二、Random随机数 1.生成随机数 2.在指定范围内随机生成一个数 三、Switch语句 四、一维数组 1.数组定义 2.获取数组长度 3.遍历数组 3.输出数组 4.数组常见…

[Backbone]CAS-ViT: Convolutional Additive Self-attention Vision Transformers

1. BaseInfo TitleCAS-ViT: Convolutional Additive Self-attention Vision Transformers for Efficient Mobile ApplicationsAdresshttps://arxiv.org/pdf/2408.03703Journal/Time202408Author清华Codehttps://github.com/Tianfang-Zhang/CAS-ViTRead20240829TableVisonTrans…

【健康问答】揭秘五大‘天然降压果‘,高血压患者常吃,血压稳稳降!-曹启富医生

曹医生&#xff0c;听说有些水果对高血压患者有特别的益处&#xff0c;能帮助降低血压&#xff0c;是真的吗&#xff1f; 曹医生说&#xff1a;确实如此。在日常饮食中&#xff0c;合理摄入一些富含特定营养素的水果&#xff0c;对于辅助控制高血压有着积极的作用。今天&#…

苹果手机系统崩溃了怎么办?详细修复指南助你快速恢复

苹果手机以其卓越的性能和稳定的系统赢得了众多用户的青睐&#xff0c;但偶尔也会出现系统崩溃的情况&#xff0c;让人措手不及。当面对苹果手机系统崩溃时&#xff0c;不必过于担心&#xff0c;本文将为你提供一套详细的修复指南&#xff0c;帮助你快速恢复手机的正常使用。 …

AI 网关零代码解决 AI 幻觉问题

作者&#xff1a;邢云阳&#xff0c;Higress Contributor 前言 什么是 AI Agent 随着大模型技术的快速发展&#xff0c;越来越多的公司在实际业务中落地了大模型应用。但是人们逐渐发现了大模型能力的不足。例如&#xff1a;由于大模型的训练数据是有限的&#xff0c;因此一…

身体发出的“高压”警报,曹启富医生教你识别高血压症状

高血压&#xff0c;这一慢性“隐形杀手”&#xff0c;正悄然影响着越来越多人的健康。随着生活节奏的加快和不良生活习惯的积累&#xff0c;其发病率逐年攀升&#xff0c;成为威胁人类健康的重要疾病之一。今天&#xff0c;我们有幸邀请到心脑血管科专家曹启富医生&#xff0c;…

摩博会15天倒计时!ONEOS 恒石智能强强联手,即将携多款MODEL系列芯片打造的智能仪表璀璨亮相

随着2024年第二十二届中国国际摩托车博览会&#xff08;摩博会&#xff09;的临近&#xff0c;国内领先的操作系统提供商ONEOS与智能硬件领域的佼佼者恒石智能宣布强强合作&#xff0c;将于9月13日至16日在重庆国家会展中心共同揭开多款MODEL系列芯片驱动的彩屏仪表的神秘面纱。…

JavaWeb - Vue项目

创建 命令行 vue create project 图形化界面 vue ui 目录结构 启动 命令行 npm run serve 端口配置 Vue的组件文件以.vue结尾 每个组件有三个部分组成&#xff1a; <template>&#xff1a;模板部分&#xff0c;由它生成HTML代码<script>&#xff1a;控制…

揭秘SQL注入漏洞:为何它成为攻击者的首选?

自Web应用程序开始广泛使用数据库以来&#xff0c;SQL注入漏洞便因其隐蔽性强、潜在危害巨大以及实施门槛相对较低等特性&#xff0c;成为了网络攻击者频繁利用的安全弱点之一。尽管这一漏洞已经存在多年&#xff0c;它仍然是企业组织在数字化转型过程中面临的最为普遍且危险的…

vue2项目 预渲染 Unable to prerender all routes 错误排查与解决方案

前言 今天在做我的Vue2项目的SEO优化时&#xff0c;我采用了prerender-spa-plugin与vue-meta-info的一套官网前端SEO预渲染方案。 但是&#xff0c;在打包时&#xff0c;报错Unable to prerender all routes。尝试了很多种网上方案&#xff0c;都没有成功&#xff0c;最后从源…

用代码和android studio创建flutter项目的区别差异

用代码创建的项目&#xff0c;在lib目录下&#xff0c;不会出现dictory文件夹&#xff0c;操作起来有些不便。