关于 [Vue Router warn]: No match found for location with path 的解决方法(转)

问题描述

通过点击菜单访问我们动态添加的路由是没有问题的
如果是强制刷新浏览器,此时,控制台会友好的提示:
[Vue Router warn]: No match found for location with path ‘xxx’ 的警告

分析

我在排除其他可能导致这种错误后,最终将问题定位到添加的 router.beforeEach 路由守卫上。这是因为强制浏览器刷新,路由又访问的是动态添加的路由,此时,进入路由守卫后未找到对应的路由记录所导致的

// 强制浏览器刷新,访问动态路由(/user/manage),进入路由守卫,
router.beforeEach((to) => {
  console.log(to.matched) 
  // 动态路由表还未添加,匹配到的是 [] 的路由记录,控制台提示警告,当后继添加完动态路由后正常显示路由视图组件
  ...
}

解决

只需要在公有的路由表最后添加段代码即可
找到路由配置文件,我的路径是src/router/index.js

const publicRoutes = [
	...
	{
	    path: '/:pathMatch(.*)*',
	    component: () => import('@/views/error-page/404')
	}
]

转自:关于 [Vue Router warn]: No match found for location with path 的解决方法-慕课网 

当出现"[Vue Router warn]: No match found for location with path "/" "这个警告时,它意味着当前路由中没有与该路径匹配的路由。这通常是因为刷新浏览器时,动态路由尚未加载的原因。为了解决这个问题,我们可以采取以下两个步骤: 步骤1:在router/index.js文件中,我们可以添加一个临时路由来处理当前路径的匹配问题。具体做法是: const { name } = router.currentRoute.value if (!name) { router.addRoute({ path: window.location.pathname, name: 'TempRoute', component: () => import('@/components/layouts/emptyLayout.vue') }) } 这样,在刷新浏览器时,就会在路由中添加一个临时的路由来匹配当前路径。 步骤2: 确保在导出router实例之前,将临时路由添加到路由中。例如: export default router 通过以上两个步骤,我们可以解决"[Vue Router warn]: No match found for location with path "/" "这个警告,并且在刷新浏览器时正确地匹配相关的路由。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [vue3 addRoute 动态路由 页面刷新后 路由失效 [Vue Router warn]: No match found for location with path](https://blog.csdn.net/weixin_43835425/article/details/116708448)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *2* *3* [解决Vue3.0 页面刷新 [Vue Router warn]: No match found for location with path 警告](https://blog.csdn.net/maoeye283301717/article/details/126482974)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值