|
本章节我们将为大家介绍 Vue.js 路由。 Vue.js 路由允许我们通过不同的 URL 访问不同的内容。 通过 Vue.js 可以实现多视图的单页Web应用(single page web application,SPA)。 安装1、直接下载 / CDN- https://unpkg.com/vue-router/dist/vue-router.js
复制代码 " d5 x9 h4 L6 k# v* {6 ^- Z0 L/ k
游客,本帖隐藏的内容需要积分高于 1 才可浏览,您当前积分为 0
3 z4 F: h8 _( g, I2 iNPM推荐使用淘宝镜像: 简单实例Vue.js + vue-router 可以很简单的实现单页应用。 以下实例中我们将 vue-router 加进来,然后配置组件和路由映射,再告诉 vue-router 在哪里渲染它们。代码如下所示: HTML 代码- r7 p5 | u" u
- <script src="https://unpkg.com/vue/dist/vue.js"></script>
$ c ?4 B' [2 W4 O% D/ ` - <script src="https://unpkg.com/vue-router/dist/vue-router.js"></script>
- s, r; |+ i& `3 L7 R: y$ G - 5 ?% D& Z7 X. m' \ u" y& S
- <div id="app">
* A. c2 \" M: u0 |1 Z - <h1>Hello App!</h1>
4 |9 s' U. _% E4 p - <p>7 Y5 U% F7 A4 q0 C! V* ^ D
- <!-- 使用 router-link 组件来导航. -->
9 o6 N% P$ J) _ - <!-- 通过传入 `to` 属性指定链接. -->2 K1 O$ f$ [" F( i
- <!-- <router-link> 默认会被渲染成一个 `<a>` 标签 -->1 S2 E' i: l4 M
- <router-link to="/foo">Go to Foo</router-link>
9 x5 n. u) s1 X - <router-link to="/bar">Go to Bar</router-link>
/ u% R4 Z3 [. |" x9 n7 f0 m) i, { - </p>1 L4 _- C5 M- f/ k7 ~# R
- <!-- 路由出口 -->
5 D ?3 H5 h( l c - <!-- 路由匹配到的组件将渲染在这里 -->
% ]1 O3 r' y2 P% a" T - <router-view></router-view>
, y7 F( P/ Z+ ? R/ v - </div>
复制代码 JavaScript 代码- // 0. 如果使用模块化机制编程,導入Vue和VueRouter,要调用 Vue.use(VueRouter)
4 b! s5 M0 ]; ?! N -
2 L; A5 v( o( T2 A7 f" u2 ^! a - // 1. 定义(路由)组件。
; @7 x- O" G) Y$ W7 v; f# ?4 V* o5 T: U - // 可以从其他文件 import 进来
/ y! Z; Y1 B! q2 l - const Foo = { template: '<div>foo</div>' }
0 N& n ]4 _8 p, | - const Bar = { template: '<div>bar</div>' }4 D1 M4 T' {# @# x2 K8 b: ]3 g8 z
- ) R3 c8 m) r7 h) ^
- // 2. 定义路由
) Q$ j9 v0 C* F - // 每个路由应该映射一个组件。 其中"component" 可以是3 v) k/ R) y; V3 g+ U& O7 Y
- // 通过 Vue.extend() 创建的组件构造器,
5 M( k/ y! A" M - // 或者,只是一个组件配置对象。4 F2 d7 k0 {( C$ h2 B
- // 我们晚点再讨论嵌套路由。
2 ]. G6 {0 K# N1 K% R - const routes = [' k" @) r" R+ r4 W$ L/ t4 X
- { path: '/foo', component: Foo },
& M' \! A4 P, q4 v/ ^ - { path: '/bar', component: Bar }
! J$ e% A# v8 b8 D0 J4 S - ]- z" ]1 u, U( B
-
7 }" i# `( u8 P6 W! n1 k- k9 r$ M - // 3. 创建 router 实例,然后传 `routes` 配置, \- U' y# q/ T) s
- // 你还可以传别的配置参数, 不过先这么简单着吧。
" K, S, T& h# `2 F& F) E - const router = new VueRouter({5 [( F* z( r0 G) ~
- routes // (缩写)相当于 routes: routes
3 C( ?* f2 Z; |' a! T6 m& n. e5 d - })+ R! j" F1 d( q" g$ x, R
- + D" y+ w5 ?/ H3 U+ p
- // 4. 创建和挂载根实例。5 F( q0 ?1 g) j) \( L# f$ w
- // 记得要通过 router 配置参数注入路由,0 h' G3 M: U$ `8 s0 ?# A% ?) R
- // 从而让整个应用都有路由功能: z7 |2 o6 H% z' B) D3 J& Z
- const app = new Vue({. A v d. L' p+ W* A M2 v" a9 ]' m# ~
- router
2 }$ y [2 O0 O0 e: _! l5 h - }).$mount('#app')% ~& V3 A' @: @: u' @2 j
- 7 t+ C% Z ^3 ^- u: S, G
- // 现在,应用已经启动了!
复制代码 NPM 路由实例接下来我们演示了一个使用 npm 简单的路由实例,开始前,请先下载该实例源代码: 游客,本帖隐藏的内容需要积分高于 1 才可浏览,您当前积分为 0 ( z5 q' u4 z4 j" q, M( C/ H
下载完后,解压该目录,重命名目录为 vue-demo,vu 并进入该目录,执行以下命令: - # 安装依赖,使用淘宝资源命令 cnpm
8 \4 P+ {/ X) v# H& w: U - cnpm install" k2 p) a# S3 b2 L& p" Q
0 }$ J/ T7 a$ t5 C9 M' v8 r+ k- # 启动应用,地址为 localhost:8080/ h0 {) k5 }! f) `& U
- cnpm run dev
复制代码 如果你需要发布到正式环境可以执行以下命令:
3 u: _: @7 h) o) l7 |1 r
* r2 Z2 q( s+ K( }4 c
3 I+ u. _6 ~- g5 w
6 R* _5 `& j! `9 g& M% {
. c- o* _! R8 w& W' I% N
+ A* q' S% J/ i, L% w; b8 N" ~" G& J. s
/ A3 P b$ U0 b# D" S
* {0 e: Z8 Z7 E$ U: ?9 l
) L2 x1 C0 ]8 h- W! U2 s% a# E6 A) W' \( x& ]8 {" j9 I
) R: `" D s0 i6 i% `5 B |