嵌套路由
<!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>