嵌套路由

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

<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>

<body>

    <div id="app">
        <router-link to="/green" tag="li">green</router-link>
        <router-link to="/fruit" tag="li">fruit</router-link>
        <router-view></router-view>
    </div>

    <template id="green">
        <div>
            蔬菜
            <router-link to="/green/organic">有机</router-link>
            <router-link to="/green/inorganic">无机</router-link>
            <router-view></router-view>
        </div>
    </template>

    <template id="fruit">
        <div>水果
            <router-link to="/fruit/sweet">甜的</router-link>
            <router-link to="/fruit/acid">酸的</router-link>
            <router-view></router-view>
        </div>
    </template>
    
</body>


<script src="https://cdn.jsdelivr.net/npm/vue@2.5.17/dist/vue.js"></script>
<script src="https://unpkg.com/vue-router@3.0.1/dist/vue-router.js"></script>
<script>
    //父路由 有蔬菜,水果,蔬菜里面有有机蔬菜,无机蔬菜 ,水果里面有甜的酸的
    let green = { template: '#green' }
    let organic = { template: "<div>有机蔬菜organic</div>" }
    let inorganic = { template: "<div>无机蔬菜inorganic</div>" }
    let fruit = { template: '#fruit' }
    let sweet = { template: "<div>甜的</div>" }
    let acid = { template: "<div>酸的</div>" }
    //路由路径映射表
    let routes = [
        //路由默认去的第一个组件
        {
            path: '',
            component: green
        },
        {
            path: "/green",
            component: green,
            children: [
                {
                    path: "",
                    component: organic
                },
                {
                    path: "organic",
                    component: organic
                },
                {
                    path: "inorganic",
                    component: inorganic
                }
            ]
        },
        {
            path: "/fruit",
            component: fruit,
            children: [
                {
                    path: "",
                    component: sweet
                },
                {
                    path: "sweet",
                    component: sweet
                },
                {
                    path: "acid",
                    component: acid
                }
            ]

        },
        //所有没有找到时候,去地址/green的组件
        {
            path: "*",
            redirect: '/green'
        }

    ]
    //实例化一个路由
    let router = new VueRouter({
        routes
    })
    let vm = new Vue({
        el: "#app",
        data: {
        },
        router
    })
</script>

</html>

file:///Users/zhiliao/zhiliao/vue/index_test.html#/

green
fruit
蔬菜 有机 无机

file:///Users/zhiliao/zhiliao/vue/index_test.html#/green
file:///Users/zhiliao/zhiliao/vue/index_test.html#/green/organic

green
fruit
蔬菜 有机 无机
有机蔬菜organic

file:///Users/zhiliao/zhiliao/vue/index_test.html#/green/inorganic

green
fruit
蔬菜 有机 无机
无机蔬菜inorganic

file:///Users/zhiliao/zhiliao/vue/index_test.html#/fruit
file:///Users/zhiliao/zhiliao/vue/index_test.html#/fruit/sweet

green
fruit
水果 甜的 酸的
甜的

file:///Users/zhiliao/zhiliao/vue/index_test.html#/fruit/acid

green
fruit
水果 甜的 酸的
酸的

命名路由

有时候,通过一个名称来标识一个路由显得更方便一些,特别是在链接一个路由,或者是执行一些跳转的时候。你可以在创建 Router 实例的时候,在 routes 配置中给某个路由设置名称。


<body>
    <div id="box">
        <router-link :to="{ name: 'foo'}">One</router-link>
        <router-link :to="{ name: 'bar'}">Two</router-link>
        <router-view></router-view>
    </div>

    <script>
        //1、定义 (路由) 模版组件
        const Foo = { template: '<div>第一个router</div>' }
        const Bar = { template: '<div>第二个router</div>' }

        //2、定义路由
        var routes = [
            {
                path: "/one",
                name: 'foo',
                component: Foo
            },
            {
                path: "/two",
                name: 'bar',
                component: Bar
            },
        ];
        // 3、创建 router 实例
        var router = new VueRouter({
            routes
        });
        // 4、创建和挂载根实例
        const app = new Vue({
            router
        }).$mount('#box')
    </script>
</body>

效果图如下:

One Two
第一个router

命名视图

有时候想同时 (同级) 展示多个视图,而不是嵌套展示,例如创建一个布局,有 sidebar (侧导航) 和 main (主内容) 两个视图,这个时候命名视图就派上用场了。你可以在界面中拥有多个单独命名的视图,而不是只有一个单独的出口。如果 router-view 没有设置名字,那么默认为 default。

<router-view class="view one"></router-view>
<router-view class="view two" name="a"></router-view>
<router-view class="view three" name="b"></router-view>

我们来看一个例子:


<body>
    <div id="box">
        <router-link to="/one">One</router-link>
        <router-view name="a_view"></router-view>
    </div>

    <script>
        //1、定义 (路由) 模版组件
        const Foo = { template: '<div>第一个router</div>' }

        //2、定义路由
        var routes = [
            {
                path: "/one",
                // name: 'foo',
                components: {
                    a_view: Foo,
                }
            }
        ];
        // 3、创建 router 实例
        var router = new VueRouter({
            routes
        });
        // 4、创建和挂载根实例
        const app = new Vue({
            router
        }).$mount('#box')
    </script>
</body>

重定向

重定向也是通过 routes 配置来完成,下面例子是从 /a 重定向到 /b:

const router = new VueRouter({
  routes: [
    { path: '/a', redirect: '/b' }
  ]
})

重定向的目标也可以是一个命名的路由:

const router = new VueRouter({
  routes: [
    { path: '/a', redirect: { name: 'foo' }}
  ]
})

甚至是一个方法,动态返回重定向目标:

const router = new VueRouter({
  routes: [
    { path: '/a', redirect: to => {
      // 方法接收 目标路由 作为参数
      // return 重定向的 字符串路径/路径对象
    }}
  ]
})

我们来看一个例子:


<body>


    <div id="box">
        <router-link to="/one">One</router-link>
        <router-link to="/two">Two</router-link>
        <router-view></router-view>
    </div>

    <!--定义模版-->
    <template id="Foo">
        <div>
            第一个router
        </div>
    </template>
    <template id="Bar">
        <div>
            第二个router
        </div>
    </template>

    <script>
        //1、定义 (路由) 模版组件

        //2、定义路由
        var routes = [
            {
                path: '/oneone', redirect: '/one' 
            },
            {
                path: "/one",
                
                component: { template: "#Foo" }
            },
            {
                path: "/two",
                component: { template: "#Bar" }
            },
        ];
        // 3、创建 router 实例
        var router = new VueRouter({
            routes
        });
        // 4、创建和挂载根实例
        const app = new Vue({
            router
        }).$mount('#box')

    </script>

</body>

Logo

前往低代码交流专区

更多推荐