返回顶部
首页 > 资讯 > 前端开发 > JavaScript >vue-router4动态路由刷新404/白屏的解决
  • 707
分享到

vue-router4动态路由刷新404/白屏的解决

vue-router4动态路由vue-router4刷新动态路由 2023-05-15 17:05:29 707人浏览 泡泡鱼
摘要

vue3+Vue-router4+vuex4+vite实现动态路由的时候,出现刷新404或者空白 一、动态路由的实现: 1、在项目一开始,通过createRouter创建路由的时候,

vue3+Vue-router4+vuex4+vite实现动态路由的时候,出现刷新404或者空白

一、动态路由的实现:

1、在项目一开始,通过createRouter创建路由的时候,使用路由实例(通常有404、login等)。

2、登录成功后,通过后台接口获取后端配置的路由,然后addRouter,并将路由存至vuex内。

3、路由跳转,通过beforeEach路由导航守卫进行跳转前的监听,判断是否有本地路由(vuex),如果没有,通过接口获取后端配置的路由,然后addRoute路由。

但遇见问题了:跳转至某个页面后,刷新404

第一步配置静态路由的是,将不匹配地址同意导航到404页面了,代码如下

{
    // 找不到路由重定向到404页面
    path: "/:pathMatch(.*)",
    component: Layout,
    redirect: "/404",
    hideMenu: true
  },

这就导致在动态权限添加路由的时候,所加的权限路由在使用地址匹配是都会被拦截到404页面。输入网址导航会,刷新页面会,在页面中通过点击等方式直接触发的路由不会出现404。

所以将此路由(404)从静态路由表去除,放到动态权限路由获取后再addRouter。

但是,当刷新页面时,会出现白屏

提示没有匹配到相应路径,也就是说路由还没加上。仔细查看vue-router官方api,有一个提示

而在代码中,router.addRoute的触发是在路由导航守卫中检测到当前未保存动态菜单信息(vuex)。在这之后用next()放行,而根据官方提示和控制台相关打印信息可以看到,warn提示在addRouter添加路由之前,所以解决方法是将next()改为next(to),触发新的一个导航,此时可以正确匹配到动态路由的相应地址。

到此这篇关于vue-router4动态路由刷新404/白屏的解决的文章就介绍到这了,更多相关vue-router4刷新动态路由内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: vue-router4动态路由刷新404/白屏的解决

本文链接: https://lsjlt.com/news/209344.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作