vue学习--前端路由(三、Vue Router嵌套路由)

Vue Router嵌套路由

1 嵌套路由用法

1.1 嵌套路由分析

  • 点击父级路由链接显示模板内容
  • 模板内容中又有子级路由链接
  • 点击子级路由链接显示子级模板内容

1.2 父路由组件模板

  • 父级路由链接
  • 父组件路由填充位
 <p> 
   <router-link to="/user">User</router-link> 
   <router-link to="/register">Register</router-link> 
 </p> 
 <div>       
   <!-- 控制组件的显示位置 -->  
   <router-view></router-view> 
 </div>

1.3 子级路由模板

  • 子级路由链接
  • 子级路由填充位
const Register = { 
    template: `<div>       
                 <h1>Register 组件</h1>       
                 <hr/> 
                 <router-link to="/register/tab1">Tab1</router-link> 
                 <router-link to="/register/tab2">Tab2</router-link> 
                 <!-- 子路由填充位置 -->     
                 <router-view/> 
               </div>` 
  }

1.4 嵌套路由配置

  • 父级路由通过children属性配置子级路由
 const router = new VueRouter({     
   routes: [      
     { path: '/user', component: User },      
     {         
        path: '/register',         
        component: Register,         
        // 通过 children 属性,为 /register 添加子路由规则         
        children: [           
          { path: '/register/tab1', component: Tab1 },           
          { path: '/register/tab2', component: Tab2 }        
        ]       
      }     
   ]   
 }) 
<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <meta http-equiv="X-UA-Compatible" content="ie=edge" />
    <title>Document</title>
    <!-- 导入 vue 文件 -->
    <script src="./lib/vue_2.5.22.js"></script>
    <script src="./lib/vue-router_3.0.2.js"></script>
  </head>
  <body>
    <!-- 被 vm 实例所控制的区域 -->
    <div id="app">
      <router-link to="/user">User</router-link>
      <router-link to="/register">Register</router-link>

      <!-- 路由占位符 -->
      <router-view></router-view>
    </div>

    <script>
      const User = {
        template: '<h1>User 组件</h1>'
      }

      const Register = {
        template: `<div>
          <h1>Register 组件</h1>
          <hr/>

          <!-- 子路由链接 -->
          <router-link to="/register/tab1">tab1</router-link>
          <router-link to="/register/tab2">tab2</router-link>

          <!-- 子路由的占位符 -->
          <router-view />
        <div>`
      }

      const Tab1 = {
        template: '<h3>tab1 子组件</h3>'
      }

      const Tab2 = {
        template: '<h3>tab2 子组件</h3>'
      }

      // 创建路由实例对象
      const router = new VueRouter({
        // 所有的路由规则
        routes: [
          { path: '/', redirect: '/user'},
          { path: '/user', component: User },
          // children 数组表示子路由规则
          { path: '/register', component: Register, children: [
            { path: '/register/tab1', component: Tab1 },
            { path: '/register/tab2', component: Tab2 }
          ] }
        ]
      })

      // 创建 vm 实例对象
      const vm = new Vue({
        // 指定控制的区域
        el: '#app',
        data: {},
        // 挂载路由实例对象
        // router: router
        router
      })
    </script>
  </body>
</html>
posted @ 2020-04-19 22:17  一纸年华  阅读(7)  评论(0编辑  收藏  举报  来源