[Vue]防止路由重复跳转

[Vue]防止路由重复跳转

js 复制代码
// 获取当前路由的原始路径(包括重定向的处理)
const currentPath = this.$route.redirectedFrom || this.$route.path;

// 判断目标路径是否与当前路径相同
if (currentPath !== item.url) {
  this.$router.push({ path: item.url });
} else {
  console.log('目标页面与当前页面相同,不进行跳转');
}
  • this.$route.redirectedFrom

重定向的来源

  • this.$route.path

this.$route.path:这是当前路由的路径(不包括查询参数和哈希)。它表示的是当前页面的实际路径,比如 /strategy/security-policy。当路由发生重定向时,this.$route.path 会反映最终的目标路径(即重定向后的路径)

  • this.$route.fullPath

这是当前路由的完整路径,包含路径、查询参数和哈希。例如,/strategy/security-policy?id=123#section1。如果路由发生了重定向,fullPath 也会是重定向后的路径。

相关推荐
一块小土坷垃2 分钟前
# ArchiCAD 29.0.2(畅享版):专为建筑师打造的BIM高效建模工具
前端·数据库·macos·开源软件
无限进步_3 分钟前
Linux指令实战:40+核心命令的用法与思维模型
linux·服务器·前端
Csvn8 分钟前
JS 技巧:设计模式(上)
前端·vue.js
中新传媒9 分钟前
德宸堂心理双师同诊
java·前端·数据库
竹林81817 分钟前
从Promise地狱到优雅监听:我用@solana/web3.js实现Solana实时交易监听的全过程
前端
Delicate21 分钟前
JavaScript 的双面人生:基本类型与引用类型的那些事儿
javascript
环流_23 分钟前
nacos环境隔离
java·服务器·前端
xuco34 分钟前
如何让流式输出的 Markdown 渲染更丝滑
前端·agent