路由嵌套,即在当前路由中注册子路由中,形成父子结构,显示子路由对应的组件,需要网址在父路由的pathname下才能实现,后面再具体演示。子路由内也可以注册它的子路由,一直下去就可以形成一个庞大的“家族”。
简单来说,就是在一个路由的页面下,继续使用路由加载新的组件;可以将嵌套路由理解为父子路由,常见的多导航界面通常就是由多层嵌套的组件组合而成。
嵌套路由还有一个优点,就是让新的页面内容展示在父组件的占位符(即router-view标签)中,这样有利于页面结构的搭建,结构清晰。
如何注册子路由呢?
需要用到一个children属性,其值为数组,数组中的每一项对应一个子路由。
代码演示就明白了:以home路由为例,为它创建三个子路由
{
path:"/home",
name:"home",
component:()=>import('../views/home/index.vue'),
children:[
{
path:"/home/home1",
name:"home1",
component:()=>import('../views/home/home1/index.vue')
},
{
path:"/home/home2",
name:"home2",
component:()=>import('../views/home/home2/index.vue')
},
{
path:"/home/home3",
name:"home3",
component:()=>import('../views/home/home3/index.vue')
},
]
}
这个时候子路由已经注册好了,子路由的path路径都是在父路由的基础下创建,我们再在对应引入组件的位置创建好组件。
结构:
最后一步,如果要想在页面渲染出来我们还需要在home路由对应的组件中添加router-view标签。
<template>
<div class="box3">
<h1>home</h1>
<!-- 方法一 -->
<router-link to="/login/ss">通过router-link标签转跳</router-link>
<!-- 方法二 -->
<button @click="rto">通过$router.push转跳</button>
<router-view></router-view>
</div>
</template>
这个时候,我们在地址栏输入子路由的网址就可以显示出来了。
效果:
我们还可以做一个优化,在home路由对应的组件加载到页面时,我们需要默认加载一个子路由时,我们需要做一个重定向,在home路由中redirect:"重定向的子路由网址"。这个时候加载home页面时默认会加一个子路由。
代码:默认显示home2
{
path:"/home",
name:"home",
component:()=>import('../views/home/index.vue'),
redirect:"/home/home2",//当网址为/home时重定向到/home/home2
children:[
{
path:"/home/home1",
name:"home1",
component:()=>import('../views/home/home1/index.vue')
},
{
path:"/home/home2",
name:"home2",
component:()=>import('../views/home/home2/index.vue')
},
{
path:"/home/home3",
name:"home3",
component:()=>import('../views/home/home3/index.vue')
},
]
}
页面:当我们网址为localhost:8080/home时自动转跳到localhost:8080/home/home2,这时子路由home2对应的组件加载到home中。