Vue-Router嵌套小demo

1.什么是嵌套路由?

嵌套路由也称之为子路由, 就是在被切换的组件中又切换其它子组件

例如: 在one界面中又有两个按钮, 通过这两个按钮进一步切换one中的内容

        <style>
        * {
            margin: 0;
            padding: 0;
        }
        
        .onepage,
        .twopage {
            width: 500px;
            height: 500px;
        }
        
        .onepage {
            background: pink;
        }
        
        .twopage {
            background: skyblue;
        }
        
        .onesub1page,
        .onesub2page {
            width: 100%;
            height: 300px;
        }
        
        .onesub1page {
            background: orangered;
        }
        
        .onesub2page {
            background: blueviolet;
        }
        
        .nj-active {
            background: skyblue;
        }
    </style>
    <script src="js/vue.js"></script>
    <!--1.导入Vue Router-->
    <script src="js/vue-router.js"></script>
    <!--这里就是MVVM中的View-->
    <div id="app">
        <router-link to="/one" tag="button">切换到第一个界面</router-link>
        <router-link to="/two" tag="button">切换到第二个界面</router-link>
        <!-- 路由出口 -->
        <!-- 路由匹配到的组件将渲染在这里 -->
        <router-view></router-view>
    </div>
    <template id="one">
    <div class="onepage">
        <p>我是第一个界面</p>
        <router-link to="/one/onesub1" tag="button">切换到第一个子界面</router-link>
        <router-link to="/one/onesub2" tag="button">切换到第二个子界面</router-link>
        <!-- 路由出口 -->
        <!-- 路由匹配到的组件将渲染在这里 -->
        <router-view></router-view>
    </div>
</template>
    <template id="onesub1">
    <div class="onesub1page">
        <p>我是第一个界面子界面1</p>
    </div>
</template>
    <template id="onesub2">
    <div class="onesub2page">
        <p>我是第一个界面子界面2</p>
    </div>
</template>
    <template id="two">
    <div class="twopage">
        <p>我是第二个界面</p>
    </div>
</template>
    <script>
        // 1.定义组件
        const onesub1 = {
            template: "#onesub1",
        };
        const onesub2 = {
            template: "#onesub2",
        };
        const one = {
            template: "#one",
            components: {
                onesub1: onesub1,
                onesub2: onesub2
            }
        };
        const two = {
            template: "#two"
        };
        // 2.定义切换的规则(定义路由规则)
        const routes = [
            // 数组中的每一个对象就是一条规则
            {
                path: '/one',
                component: one,
                children: [{
                    // 注意点: 如果是嵌套路由(子路由), 那么不用写一级路径的地址, 并且也不用写/
                    path: "onesub1",
                    component: onesub1
                }, {
                    // 注意点: 如果是嵌套路由(子路由), 那么不用写一级路径的地址, 并且也不用写/
                    path: "onesub2",
                    component: onesub2
                }]
            },

            {
                path: '/two',
                component: two
            }
        ];
        // 3.根据自定义的切换规则创建路由对象
        const router = new VueRouter({
            routes: routes,
            linkActiveClass: "nj-active"
        });
        // 这里就是MVVM中的View Model
        let vue = new Vue({
            el: '#app',
            // 4.将创建好的路由对象绑定到Vue实例上
            router: router,
            // 这里就是MVVM中的Model
            data: {},
            // 专门用于存储监听事件回调函数
            methods: {},
            // 专门用于定义计算属性的
            computed: {},
            // 专门用于定义局部组件的
            components: {
                one: one,
                two: two
            }
        });
        // console.log(vue.$route);
    </script>

 

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小白小白从不日白

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值