嵌套路由和动态路由匹配

一、嵌套路由:可在单页应用框架下开发多页应用。

思想:嵌套路由其实是 router-view 的细化,router-view 第一层中包含一个 router-view,路由children路由。每一个坑挖好都要对应一个单独的组件。

配置路由对象:在嵌套路由中,下级路由的信息配置在上级路由信息对象的 children 属性里面,children 属性里面可以配置多套路由信息对象。

// 2.创建路由对象
var router = new VueRouter({
// 3.配置路由对象
  routes:[
  // 4.创建路由匹配的规则
    {
      // 动态路由参数以冒号开头
      path:'/home',
      name:'home',
      component:Home,
      // 嵌套路由
      children:[
        {
          path:'song',
          name:'song',
          component:Song
        },
        {
          path:'movie',
          name:'movie',
          component:Movie
        }
      ]
    }
  ]    
});

 代码如下:

    <div id="app"></div>
    <script type="text/javascript" src="../vue/vue.js"></script>
    <script type="text/javascript" src="./node_modules/vue-router/dist/vue-router.js"></script>
    <script type="text/javascript">
        // 地址栏 路由范式
        // (1)xxx.html#/user/1 params 动态路由参数
        // (2)ooo.html#/user?userId = 1 query
        // 1.声明路由组件
        var Song = {
            template:'<div>我是歌曲组件</div>',
            created(){
                console.log(this.$route);
                console.log(this.$router);
            }
        }
        var Movie = {
            template:'<div>我是电影组件</div>',
            created(){
                console.log(this.$route);
                console.log(this.$router);
            }
        }
        // /home/song
        // /home/movie
        var Home = {
            template:` 
                <div>首页内容
                    <br/>
                    <router-link to='/home/song'>歌曲</router-link>
                    <router-link to='/home/movie'>电影</router-link>

                    <!-- 路由出口 -->
                    <router-view></router-view>
                </div>
            `
        }
        // 2.创建路由对象
        var router = new VueRouter({
            // 3.配置路由对象
            routes:[
                // 4.创建路由匹配的规则
                {
                    // 动态路由参数以冒号开头
                    path:'/home',
                    name:'home',
                    component:Home,
                    // 嵌套路由
                    children:[
                        {
                            path:'song',
                            name:'song',
                            component:Song
                        },
                        {
                            path:'movie',
                            name:'movie',
                            component:Movie
                        }
                    ]
                }
            ] 
        });
        // 5.抛出两个全局组件 router-link router-view
        // 抛出两个对象 $router $route(路由信息对象) 挂载到了Vue实例化对象
        var App = {
            template:`
                <div>
                    <!-- router-link默认会被渲染为a标签,router-view默认会被渲染为herf标签 -->
                    <router-link :to="{name:'home'}">首页</router-link> 
                    <!-- 6.路由组件的出口 -->
                    <router-view></router-view>
                </div>
            `
        };
        // 6.将配置好的路由关联到vue实例对象中
        new Vue({
            el:'#app',
            router:router,
            template:` 
                <App/>
            `,
            components:{
                App,
                router,
            }
        });
    </script>

 

 二、动态路由:组件相同,数据不同。

通过 watch 监听器中的  '$route'(to, from){ }  可对路有变化作出响应。

    <div id="app"></div>
    <script type="text/javascript" src="../vue/vue.js"></script>
    <script type="text/javascript" src="./node_modules/vue-router/dist/vue-router.js"></script>
    <script type="text/javascript">
        // 地址栏 路由范式
        // (1)xxx.html#/user/1 params 动态路由参数
        // (2)ooo.html#/user?userId = 1 query
        // 1.声明路由组件
        var ComDesc = {
            data(){
                return{
                    msg:''
                }
            },
            template:`
                <div>
                    {{ msg }}
                </div>`,
            created(){
                this.msg = '安卓';
                console.log(1);
            },
       // 监听路由 watch:{
'$route'(to, from){ // 对路由变化作出响应 console.log(to); console.log(from); this.msg = to.params.id; } } } // /timeline/andorid // /timeline/frontend var Timeline = { template:` <div id='timeline'> <router-link :to="{name:'comDesc',params:{id:'adroid'}}">安卓</router-link> <router-link :to="{name:'comDesc',params:{id:'frontend'}}">前端</router-link> <!-- 路由出口 --> <router-view></router-view> </div> ` } var Pins = { template:` <div>我是沸点</div> ` } // 2.创建路由对象 var router = new VueRouter({ // 3.配置路由对象 routes:[ // 4.创建路由匹配的规则 { // 动态路由参数以冒号开头 path:'/timeline', name:'timeline', component:Timeline, children:[ { path:'/timeline/:id', name:'comDesc', component:ComDesc } ] }, { path:'/pins', component:Pins } ] }); // 5.抛出两个全局组件 router-link router-view // 抛出两个对象 $router $route(路由信息对象) 挂载到了Vue实例化对象 var App = { template:` <div> <!-- router-link默认会被渲染为a标签,router-view默认会被渲染为herf标签 --> <router-link :to="{name:'timeline'}">首页</router-link> <router-link to='/pins'>沸点</router-link> <!-- 6.路由组件的出口 --> <router-view></router-view> </div> ` }; // 6.将配置好的路由关联到vue实例对象中 new Vue({ el:'#app', router:router, template:` <App/> `, components:{ App, router, } }); </script>

 

 

 相同组件,但是数据不同。

posted @ 2022-11-18 14:25  炒股沦为首负  阅读(172)  评论(0编辑  收藏  举报