Vue路由嵌套

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>vue路由嵌套 </title>
    <script src="../js/vue.js"></script>
    <script src="../js/vue-router_3.0.2.js"></script>
</head>

<body>
    <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></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 }
                    ]
                }
            ]
        });

        const vm = new Vue({

            el: '#app',
            data: {

            },
            //挂载路由实例对象
            //router:router
            router
        });
    </script>
</body>

</html>

posted @ 2021-11-09 22:34  丁帅帅dss  阅读(49)  评论(0)    收藏  举报