这是官网中的一个例子:
HTML如下:
<script src="https://unpkg.com/vue/dist/vue.js"></script> <script src="https://unpkg.com/vue-router/dist/vue-router.js"></script> <div id="app"> <p> <!-- 使用 router-link 组件来导航. --> <!-- 通过传入 `to` 属性指定链接. --> <!-- <router-link> 默认会被渲染成一个 `<a>` 标签 -->
<!-- 'to'属性指定链接为router中的id--> <router-link to="/user/foo">/user/foo</router-link> <router-link to="/user/foo/profile">/user/foo/profile</router-link> <router-link to="/user/foo/posts">/user/foo/posts</router-link> </p> <!-- 最顶层的路由出口 对应的组件User --> <!-- 路由匹配到的组件将渲染在这里 --> <router-view></router-view> </div>
js如下:// 0. 如果使用模块化机制编程,導入Vue和VueRouter,要调用 //Vue.use(VueRouter) // 1. 定义(路由)组件User。 // 可以从其他文件 import 进来 const User = { template: ` <div class="user"> <h2>User {{ $route.params.id }}</h2> //下一层的出口,对应组件UserHome,UserProfile,UserPosts <router-view></router-view> </div> ` } // 定义组件User的子组件UserHome,UserProfile,UserPosts。 // 可以从其他文件 import 进来 const UserHome = { template: '<div>Home</div>' } const UserProfile = { template: '<div>Profile</div>' } const UserPosts = { template: '<div>Posts</div>' } // 2. 定义路由routes,并将`routes` 配置传入创建的 router 实例 // 每个路由应该映射一个组件。 其中"component" 可以是 // 通过 Vue.extend() 创建的组件构造器, // 或者,只是一个组件配置对象。 const router = new VueRouter({ routes: [ { path: '/user/:id', component: User, children: [ // UserHome will be rendered inside User's <router-view> // when /user/:id is matched //"/user/foo"+''为to="/user/foo" { path: '', component: UserHome }, // UserProfile will be rendered inside User's <router-view> // when /user/:id/profile is matched //"/user/foo"+'profile'为to="/user/foo/profile" { path: 'profile', component: UserProfile }, // UserPosts will be rendered inside User's <router-view> // when /user/:id/posts is matched //"/user/foo"+'posts'为to="/user/foo/posts" { path: 'posts', component: UserPosts } ] } ] }) // 4. 创建和挂载根实例。 // 记得要通过 router 配置参数注入路由, // 从而让整个应用都有路由功能 const app = new Vue({ router }).$mount('#app')
实际生活中的应用界面,通常由多层嵌套的组件组合而成。同样地,URL 中各段动态路径也按某种结构对应嵌套的各层组件,例如:
/user/foo/profile /user/foo/posts +------------------+ +-----------------+ | User | | User | | +--------------+ | | +-------------+ | | | UserProfile | | +------------> | | UserPosts | | | | | | | | | | | +--------------+ | | +-------------+ | +------------------+ +-----------------+
第一段动态路径:/user/foo 对应的父组件为:User
一个『路径参数』使用冒号 : 标记foo为id
第二段动态路径:/profile 对应的父组件为:UserProfile
你可以在一个路由中设置多段『路径参数』,对应的值都会设置到
$route.params
中。例如:
模式 | 匹配路径 | $route.params |
---|---|---|
/user/:username | /user/evan | {
username: 'evan' } |
/user/:username/post/:post_id | /user/evan/post/123 | { username: 'evan', post_id: 123 } |