|
本章节我们将为大家介绍 Vue.js 路由。 Vue.js 路由允许我们通过不同的 URL 访问不同的内容。 通过 Vue.js 可以实现多视图的单页Web应用(single page web application,SPA)。 安装1、直接下载 / CDN- https://unpkg.com/vue-router/dist/vue-router.js
复制代码 - A0 n9 U; R s7 S
游客,本帖隐藏的内容需要积分高于 1 才可浏览,您当前积分为 0
! W8 E9 Z3 f# n1 FNPM推荐使用淘宝镜像: 简单实例Vue.js + vue-router 可以很简单的实现单页应用。 以下实例中我们将 vue-router 加进来,然后配置组件和路由映射,再告诉 vue-router 在哪里渲染它们。代码如下所示: HTML 代码3 F" W2 T( B5 N w
- <script src="https://unpkg.com/vue/dist/vue.js"></script>
, m0 B' g9 s, \! e8 c# E9 u& | - <script src="https://unpkg.com/vue-router/dist/vue-router.js"></script> k6 @# \4 b# o0 s# }/ ^: H- c; F
-
9 w) L# @" T; f% X# R - <div id="app">
9 z7 I$ \4 V" t; h: A1 _: L) C- l - <h1>Hello App!</h1>% N- H* K B1 f6 x
- <p>
! I0 P/ @( [0 c" \ v - <!-- 使用 router-link 组件来导航. -->0 R6 e; `4 j t1 n* ~# R& x1 L+ l$ o+ w
- <!-- 通过传入 `to` 属性指定链接. -->) u' y, z& d8 p L3 h
- <!-- <router-link> 默认会被渲染成一个 `<a>` 标签 -->
' @/ S3 m% E$ M - <router-link to="/foo">Go to Foo</router-link>
8 b T8 X8 D( K# `! F5 J) Q* c - <router-link to="/bar">Go to Bar</router-link>
" G+ D6 ?# ~( z7 ^ - </p>
: \. `; b) t5 Z - <!-- 路由出口 -->1 ?3 m7 n5 e4 V2 m5 \2 d
- <!-- 路由匹配到的组件将渲染在这里 -->. y8 v7 B( D: n* `/ r1 H; o
- <router-view></router-view>
0 T4 {) Q) A7 d# @* u y! Z" S8 l# O - </div>
复制代码 JavaScript 代码- // 0. 如果使用模块化机制编程,導入Vue和VueRouter,要调用 Vue.use(VueRouter)
# K. r* S) w) _ -
0 u2 l9 J4 M/ D7 q2 V" d" p - // 1. 定义(路由)组件。+ W4 `2 C2 P3 M a6 u/ J
- // 可以从其他文件 import 进来4 p: t% Y; g' R/ q2 W j# t% Z; \( i
- const Foo = { template: '<div>foo</div>' }
g( c* L9 D4 |% s" A! U% H6 ~3 o - const Bar = { template: '<div>bar</div>' }9 s0 C+ @. l% D4 \; l
-
* {# a# r% |1 Y$ O - // 2. 定义路由! }) Y" m. y1 V1 r2 `( {
- // 每个路由应该映射一个组件。 其中"component" 可以是+ `5 R8 f: j4 J# u* t3 h
- // 通过 Vue.extend() 创建的组件构造器,
) a2 p0 }0 {+ F4 f+ G. M, e+ Z - // 或者,只是一个组件配置对象。+ L5 \! w7 p+ b& J
- // 我们晚点再讨论嵌套路由。7 c' g$ a- W6 g( b i0 X) E( ]- \
- const routes = [
3 y6 p: o6 t& U - { path: '/foo', component: Foo },
* E+ _; n3 B" A9 Q- s7 Z - { path: '/bar', component: Bar }% Z8 n6 b5 P% c% [0 n
- ]- z+ q1 I" F5 _9 E, `& q
-
5 {$ h w, n& @0 n+ d - // 3. 创建 router 实例,然后传 `routes` 配置
/ a7 o7 c: b* t$ D7 `& k5 N9 H' J - // 你还可以传别的配置参数, 不过先这么简单着吧。
3 Q; e: u: l; D: f; R! o - const router = new VueRouter({! X$ z' w |5 |( x. a
- routes // (缩写)相当于 routes: routes
/ r1 Q8 s5 e' ?) r - })
5 M" o6 r6 m! {; R, Z% s \( g) | -
2 ~6 b6 s5 L8 o - // 4. 创建和挂载根实例。( W: e2 q6 x4 P& o9 r6 [) Y0 Q: j
- // 记得要通过 router 配置参数注入路由,
* E9 F2 p' R! [' h- W7 v! ~, E - // 从而让整个应用都有路由功能
# k- T7 e: U+ j; S - const app = new Vue({4 V/ f( I9 D! \4 n3 B/ j
- router9 z5 F& q* }7 j2 R& U
- }).$mount('#app')5 z' P! o0 p1 b0 t# u" j
- 1 m" ^9 d; {$ S, z7 \
- // 现在,应用已经启动了!
复制代码 NPM 路由实例接下来我们演示了一个使用 npm 简单的路由实例,开始前,请先下载该实例源代码: 游客,本帖隐藏的内容需要积分高于 1 才可浏览,您当前积分为 0
; t- \- } B* _+ Q下载完后,解压该目录,重命名目录为 vue-demo,vu 并进入该目录,执行以下命令: - # 安装依赖,使用淘宝资源命令 cnpm) `/ A; p4 l6 ^: V4 n- _
- cnpm install; R2 _; V9 ~8 T$ o
- 8 X M: I- M% [. L8 q3 `" N
- # 启动应用,地址为 localhost:8080: W) l. U6 P/ H" ^$ V7 I
- cnpm run dev
复制代码 如果你需要发布到正式环境可以执行以下命令:
, G/ N0 N: _8 Q' o
3 c. o7 U9 w* b; ^! @9 h6 K4 K1 p3 E2 R/ ]' i; q0 B7 w
5 y/ n* D( T2 F1 j& T* P! h' U
0 M7 b' U7 e4 f, f$ Z! u
. {, I- D4 b5 i$ l
. t. c% v) X8 g, g. M7 c: [: L% H7 V; x2 b
5 [+ Z% @9 e/ L# c+ t; [1 X. t9 Q |# L" `! p, w: M3 \
' e5 K; k4 f- k- E
3 Z |0 V* F9 H. B: n
|