整理了部分Vue Router路由无法跳转问题:
router-view
只能被顶层路由配置内容使用:此问题异常表现在路由跳转但页面不变
router-view
:此问题异常表现在路由跳转但页面不变
/
/
,则代表为全路径,需要包含父路由路径重复路由
时,会触发NavigationDuplicated
错误
<template>
<div id="app">
<router-view/>
div>
template>
子层路由视图,只能子路由配置可以使用,比如/parent
路由中的children子路由配置child
换句话说:子路由可以跳转则必需对应父路由的组件中村啊在
<template>
<div id="parent">
Parent Content
<router-view/>
div>
template>
<template>
<div id="child">
Child Content
div>
template>
name=Home,Parent
等路由只能用在App.vue
中的
中,如name=Child
路由只能用在Parent.vue
中的
,并且需要使用,
name=Child
路由中继续配置children
子路由Child.vue
组件,如name=NewChild
,并在其中配置children
子路由// router配置
export default new Router({
routes: [
{
path: '/',
name: 'Home',
redirect:'/parent', // 可以使用App.vue中的顶层路由视图
},
{
path: '/parent',
name: 'Parent',
component: Parent,
children: [
{
path: 'child', // 非全路径配置时,子路径开头无需`/`,只需子路径`child`
// path : '/parent/child', // 也可以配置全路径
name: 'Child',
component: Child,
// children: [] // 如果Child组件中仍有 ,则可以继续配置子路由
},
],
},
{
path: '/new-child',
name: 'NewChild',
component: Child,
// children: [] // 如果Child组件中仍有 ,则可以继续配置子路由
},
],
})
/
开头代表全路径配置,需要包含父路由路径,如path:'/parent/child'
/
开头,自动继承父路由路径,如path:'child'
// router配置
export default new Router({
routes: [
{
path: '/parent',
name: 'Parent',
component: Parent,
children: [
{
path: 'child', // 非全路径配置时,子路径开头无需`/`,只需子路径`child`
// path : '/parent/child', // 也可以配置全路径
name: 'Child',
component: Child,
},
],
},
],
})
vue-router 不知道哪个版本开始的问题,小编没关心过这个,解决内容可以参考.
当准备跳转的路由是当前路由是,即假如当前路由时/parent
,仍旧执行this.$router.push('/parent')
就会报类似以下错误:
NavigationDuplicated: Avoided redundant navigation to current location: "/data-manage".
at createRouterError (webpack-internal:///./node_modules/vue-router/dist/vue-router.esm.js:2053:15)
at createNavigationDuplicatedError (webpack-internal:///./node_modules/vue-router/dist/vue-router.esm.js:2023:15)
at HTML5History.confirmTransition (webpack-internal:///./node_modules/vue-router/dist/vue-router.esm.js:2340:18)
at HTML5History.transitionTo (webpack-internal:///./node_modules/vue-router/dist/vue-router.esm.js:2267:8)
at HTML5History.push (webpack-internal:///./node_modules/vue-router/dist/vue-router.esm.js:2613:10)
at eval (webpack-internal:///./node_modules/vue-router/dist/vue-router.esm.js:3043:24)
at new Promise ()
at VueRouter.push (webpack-internal:///./node_modules/vue-router/dist/vue-router.esm.js:3042:12)
at VueComponent.goto (webpack-internal:///./node_modules/babel-loader/lib/index.js!./node_modules/vue-loader/lib/selector.js?type=script&index=0!./src/components/commons/layout/SideBar.vue:24:26)
at click (webpack-internal:///./node_modules/vue-loader/lib/template-compiler/index.js?{"id":"data-v-3cb2454e","hasScoped":false,"transformToRequire":{"video":["src","poster"],"source":"src","img":"src","image":"xlink:href"},"buble":{"transforms":{}}}!./node_modules/vue-loader/lib/selector.js?type=template&index=0!./src/components/commons/layout/SideBar.vue:17:30)
解决方法:
vue-router
的push
方法this.$router.push
在router/index.js
(在自己项目的路由配置中哈,不要非要较真~)重写VueRouter.push
方法
import VueRouter from 'vue-router'
const VueRouterPush = VueRouter.prototype.push
VueRouter.prototype.push = function push(to) {
return VueRouterPush.call(this, to).catch(err => err)
}
this.$router.push(url).catch(() => {})
推荐提取为统一公共方法,如:
export const routerPush = (url) => {this.$router.push(url).catch(() => {})}
如果路径非当前路径才允许跳转,否则不跳转,同样推荐提取为统一公共方法
// currentUrl存储在内存中
if (this.$route.path !== currentUrl) {
this.$router.push({ path: currentUrl })
}