vue路由刷新404问题~

你们好,我是金金金。

场景

  • 侧边栏点击菜单,渲染对应路由页面没有任何问题,当我刷新浏览器出现404(这种情况只出现在动态路由上,静态路由刷新没问题)

排查

我先贴一下代码

  • 路由守卫代码
  • 静态路由代码
  • 动态路由代码

当只有选中动态路由 渲染出来的菜单时候刷新浏览器才会404,我猜想是不是因为没匹配上路由导致?

  1. 首先排查路由守卫 ,当我点击了一个动态路由渲染出的菜单时,刷新页面时发现matched为空,难怪一直404,原来如此!原因:因为当页面刷新时,路由数据也被清空了,此时路由数据里面只有静态路由的数据,动态路由的数据还没push进来,这也就是为什么静态路由刷新没事,动态路由刷新404的原因。
  2. 我们把这行代码注释,我发现,刷新依旧如此还是404
  3. 通过第二点可以看到,为什么to.path直接变成404了呢?接着我在点击侧边栏的时候输出了一下路由数据
  • 问题已经浮现了,原因就是/:pathMatch(.*)*没在最后一个,导致/system/roles路径先匹配上/:pathMatch(.*)*导致404,咱们把/:pathMatch(.*)*放在最后一个路由即可!!!

造成error的原因

  1. 路由守卫当中的to.matched为空数组导致
  2. /:pathMatch(.*)*未写在路由的最后

解决

  1. 注释掉路由守卫的to.matched这行代码
  2. /:pathMatch(.*)*放在动态路由的最后面
  • 已经测试,刷新正常!

总结

  1. 因为浏览器在刷新时,路由数据也被清空了,此时如果是动态路由的话,路由守卫当中的to.matched此时肯定为空数组(因为动态路由此时还未加载上),所以导致404
  2. /:pathMatch(.*)*没放在路由的最后一个 导致还没匹配完所有的路由就被匹配上从而重定向到404页面了。
  • 编写有误还请大佬指正,万分感谢。
相关推荐
ai超级个体1 分钟前
别再吹牛了,100% Vibe Coding 存在无法自洽的逻辑漏洞!
前端·ai·ai编程·vibe coding
Mike_jia24 分钟前
🎓 OpenMAIC 终极指南:清华开源的多智能体 AI 互动课堂平台
前端
踩着两条虫28 分钟前
告别低代码“黑盒”!VTJ.PRO 2.0:用AI与自由重塑Vue3开发
前端·低代码·ai编程
OpenTiny社区34 分钟前
WebAgent :基于 MCP 协议打造的智能应用“超级路由器”
前端·agent·mcp
dweizhao1 小时前
别再用 Figma 画线框图了,Google 这款免费工具直接出 UI 稿
前端
han_1 小时前
JavaScript设计模式(五):装饰者模式实现与应用
前端·javascript·设计模式
ProgramHelpOa1 小时前
Amazon SDE Intern OA 2026 最新复盘|70分钟两题 Medium-Hard
java·前端·javascript
smchaopiao2 小时前
如何用CSS和JS搞定全屏图片展示
前端·javascript·css
酉鬼女又兒2 小时前
零基础快速入门前端CSS Transform 与动画核心知识点及蓝桥杯 Web 应用开发考点解析(可用于备赛蓝桥杯Web应用开发)
开发语言·前端·css·职场和发展·蓝桥杯·html
山川行2 小时前
Python快速闯关8:内置函数
java·开发语言·前端·笔记·python·学习·visual studio