|
本章节我们将为大家介绍 Vue.js 路由。 Vue.js 路由允许我们通过不同的 URL 访问不同的内容。 通过 Vue.js 可以实现多视图的单页Web应用(single page web application,SPA)。 安装1、直接下载 / CDN- https://unpkg.com/vue-router/dist/vue-router.js
复制代码
. o8 g* f0 d1 t9 R& I游客,本帖隐藏的内容需要积分高于 1 才可浏览,您当前积分为 0 4 F5 i" ]# z5 K8 K1 c \
NPM推荐使用淘宝镜像: 简单实例Vue.js + vue-router 可以很简单的实现单页应用。 以下实例中我们将 vue-router 加进来,然后配置组件和路由映射,再告诉 vue-router 在哪里渲染它们。代码如下所示: HTML 代码
P6 e- q) Y4 b- <script src="https://unpkg.com/vue/dist/vue.js"></script>
! `0 q8 {. e. {% ]+ }5 T s$ _ k, W - <script src="https://unpkg.com/vue-router/dist/vue-router.js"></script>
. l; \# p1 A$ n0 A! Z& p. B - 3 E# X0 Z8 m' u! N, f; \1 @" X
- <div id="app">; q7 l7 s5 i, R+ p, v ~; {# G9 u
- <h1>Hello App!</h1>$ X; R+ H8 L) u0 ~
- <p>, p. z# _- J1 g2 [ D! r! ^+ ]
- <!-- 使用 router-link 组件来导航. --># S# p" ?: `3 S4 |0 [% E% H
- <!-- 通过传入 `to` 属性指定链接. -->
1 i1 m% D z3 | - <!-- <router-link> 默认会被渲染成一个 `<a>` 标签 -->
* z1 c5 B1 @: r' k3 r* t - <router-link to="/foo">Go to Foo</router-link>: [$ w- _. j4 O/ d! h
- <router-link to="/bar">Go to Bar</router-link>
9 ?0 |$ ~- B' t f7 q - </p>: i; v+ v) R) g2 t h$ F6 m
- <!-- 路由出口 --> R6 G9 c$ |/ U( Q
- <!-- 路由匹配到的组件将渲染在这里 -->1 q3 ]6 D2 ?6 v! k P7 t2 U
- <router-view></router-view>0 [+ U2 x7 a. R( t; _5 r$ f6 d2 N
- </div>
复制代码 JavaScript 代码- // 0. 如果使用模块化机制编程,導入Vue和VueRouter,要调用 Vue.use(VueRouter). b7 S4 d a/ t0 p" K, S1 t
-
0 K5 X7 y# D* P) c - // 1. 定义(路由)组件。: y( |+ m9 i# m" P
- // 可以从其他文件 import 进来
; n1 N, q- s0 d S% e - const Foo = { template: '<div>foo</div>' }
* c2 |( [9 S, W- A# v - const Bar = { template: '<div>bar</div>' }& c0 j S# j( n, F
- 2 \" ]5 T3 t- D( A7 i8 L
- // 2. 定义路由1 K( H9 O: A2 `( a- u! b2 t
- // 每个路由应该映射一个组件。 其中"component" 可以是! C9 Y9 d b& l1 P. {
- // 通过 Vue.extend() 创建的组件构造器,
$ k- n1 O; m$ T8 x. F2 p k - // 或者,只是一个组件配置对象。
+ h# G' y1 R! z G - // 我们晚点再讨论嵌套路由。! |! h; E3 }# w+ b( _; t. q( `
- const routes = [
' [% K3 _* x- G }! r& S# j - { path: '/foo', component: Foo },6 Z; Q9 Z, m* F( w3 Y V0 R5 r
- { path: '/bar', component: Bar }
7 Y; r- p& A6 B - ]; p R" y5 ]6 }+ G
- " b( e8 F5 O5 t' x# n
- // 3. 创建 router 实例,然后传 `routes` 配置
) e1 c# v( @ F - // 你还可以传别的配置参数, 不过先这么简单着吧。7 P/ b5 G3 B0 r) a$ x* h) u. }
- const router = new VueRouter({
4 R4 X4 Q' a: B' p" \* v1 y) G& E - routes // (缩写)相当于 routes: routes/ w D, c1 |* c0 H8 O$ U2 L' U
- })2 c' r; e: @, a- V- b' o
-
. a' b- q' d _8 } - // 4. 创建和挂载根实例。
$ C4 G% U' o& p6 T, X- s" y; B - // 记得要通过 router 配置参数注入路由,
2 d+ c0 K* H8 q# f+ U - // 从而让整个应用都有路由功能
{+ M7 D! l3 P - const app = new Vue({. ^5 E! R( Y3 w6 T" f3 A
- router1 H4 H \! }( r2 Q# C; I
- }).$mount('#app')
6 m& T/ \* x1 H0 M" \ C/ d/ P* D, u -
! q5 d# y$ o% }/ v; l - // 现在,应用已经启动了!
复制代码 NPM 路由实例接下来我们演示了一个使用 npm 简单的路由实例,开始前,请先下载该实例源代码: 游客,本帖隐藏的内容需要积分高于 1 才可浏览,您当前积分为 0
3 n8 t6 i7 I9 D `0 ?- k1 C下载完后,解压该目录,重命名目录为 vue-demo,vu 并进入该目录,执行以下命令: - # 安装依赖,使用淘宝资源命令 cnpm7 @1 Y9 ^+ G4 t/ O: P# w) E
- cnpm install$ n3 ?; b8 u3 p) q# C! B0 F
. V8 Z1 g1 d- g# w) P! T- # 启动应用,地址为 localhost:8080( A0 {2 V3 O2 N, ^. r+ c2 O7 ^
- cnpm run dev
复制代码 如果你需要发布到正式环境可以执行以下命令:" y- H6 H3 L; T' O0 a! M
: ]" Z& @% N5 U/ ^4 M
4 u" ~7 S4 O& [, ~/ m: {- u/ L
; i9 [# W5 ?! y9 Z: U& B @4 F( i$ R; x$ `" M8 x, M/ ^
% P* e& `: X4 ?
( Z5 y, w9 f( v+ i8 d' R
- i# F+ u& z& m+ K9 g' t5 t% d
( ~6 @& u; ^3 j# P1 z( A9 G
9 {; j3 q- Z4 |9 U
; _( }8 l8 U. V$ K# I, i# A" @5 o5 ]/ p& Z# u3 w
|