cncml手绘网
标题: Vue.js 路由 [打印本页]
作者: admin 时间: 2018-7-4 11:44
标题: Vue.js 路由
本章节我们将为大家介绍 Vue.js 路由。
Vue.js 路由允许我们通过不同的 URL 访问不同的内容。
通过 Vue.js 可以实现多视图的单页Web应用(single page web application,SPA)。
安装1、直接下载 / CDN- https://unpkg.com/vue-router/dist/vue-router.js
复制代码 ; R7 q) D, k1 D+ q
0 I- d5 D" ~& T9 e% G5 nNPM推荐使用淘宝镜像:
简单实例Vue.js + vue-router 可以很简单的实现单页应用。
以下实例中我们将 vue-router 加进来,然后配置组件和路由映射,再告诉 vue-router 在哪里渲染它们。代码如下所示:
HTML 代码
3 u& A# m+ j3 t$ r- <script src="https://unpkg.com/vue/dist/vue.js"></script>3 e4 D6 z3 Z" S0 }! r
- <script src="https://unpkg.com/vue-router/dist/vue-router.js"></script>
- H1 A2 g3 E; ]. W5 z6 h8 ` - 0 {' e0 X6 Y" ^
- <div id="app">7 u. Q& G0 |) N0 D
- <h1>Hello App!</h1>& o# y9 @; N; T' T
- <p>" C, {) i, S/ D* [. @( d
- <!-- 使用 router-link 组件来导航. -->* Z, z) x; g! l, M4 A- ~5 a: a
- <!-- 通过传入 `to` 属性指定链接. -->* C V7 L9 h1 `8 K% z
- <!-- <router-link> 默认会被渲染成一个 `<a>` 标签 -->
! n$ o8 ?+ l8 u - <router-link to="/foo">Go to Foo</router-link>4 }, |$ ~2 I; { Y& L) l
- <router-link to="/bar">Go to Bar</router-link>! k9 n8 D) |4 L& G, p
- </p>
7 b- M; }1 @, O! F# }; f8 {7 _ - <!-- 路由出口 -->0 V) u2 k# f+ p6 `. s
- <!-- 路由匹配到的组件将渲染在这里 -->9 o. k5 _2 W/ W5 N
- <router-view></router-view>
& ?, }3 A, q. N- Z+ p. R- u( _ - </div>
复制代码 JavaScript 代码- // 0. 如果使用模块化机制编程,導入Vue和VueRouter,要调用 Vue.use(VueRouter)9 b/ g& s6 b; y
-
5 f/ {- e7 i6 J$ i; }9 h - // 1. 定义(路由)组件。/ P' R/ B( Y. A& {) m, e1 t
- // 可以从其他文件 import 进来) X7 v; {2 E. w' f
- const Foo = { template: '<div>foo</div>' }
# K1 E* v6 S2 \' O$ ~2 j# {$ \4 b U* | - const Bar = { template: '<div>bar</div>' }* o1 Y$ M0 @0 }6 y% ?; k2 m \/ }
- 9 f5 }3 y- K; w9 ?; ]" ?4 N" R
- // 2. 定义路由+ o u5 ]2 d" Y v' f
- // 每个路由应该映射一个组件。 其中"component" 可以是
# Y# N$ K3 M* p4 | - // 通过 Vue.extend() 创建的组件构造器,/ I- j+ Z6 D" {! J; a8 e) d
- // 或者,只是一个组件配置对象。
- R6 C, W: H) U% ]# Q - // 我们晚点再讨论嵌套路由。
- o, s9 w4 m& i$ o2 V& v - const routes = [
% @& ^: ]0 u2 k1 m& N - { path: '/foo', component: Foo },
: q; L' z% y- E* }6 E: Y' V/ S+ c - { path: '/bar', component: Bar }( {- w' G! h, f( |. i7 t
- ]( ~' }; r1 v; z/ A6 q# D5 ~
- . t1 Y) x9 N9 p$ C- A. C
- // 3. 创建 router 实例,然后传 `routes` 配置
- ^4 P9 ~8 G3 r' h - // 你还可以传别的配置参数, 不过先这么简单着吧。, ~0 i2 O. j, [" v. h9 y( u* Y
- const router = new VueRouter({
+ K8 y; K% Z" w0 g! c. i* q - routes // (缩写)相当于 routes: routes/ @7 `& [* n( ]3 a) |
- })2 F, r; ?4 l, \2 H
-
' C& m0 C9 n {; G/ l1 f/ S - // 4. 创建和挂载根实例。/ x# H5 x: S0 E# d2 N- F6 Q
- // 记得要通过 router 配置参数注入路由,
6 W0 j; `3 {3 D' [ - // 从而让整个应用都有路由功能
) B/ p: U3 Y6 B. N8 F" e* n - const app = new Vue({
. }0 x! ]. U5 u - router4 t' O/ r( E& \8 B5 K3 N9 z: n
- }).$mount('#app'); F0 Y U3 m7 H0 l
-
( p6 V1 H. j& m0 ]5 g - // 现在,应用已经启动了!
复制代码 NPM 路由实例接下来我们演示了一个使用 npm 简单的路由实例,开始前,请先下载该实例源代码:
/ X O' e) T9 V
下载完后,解压该目录,重命名目录为 vue-demo,vu 并进入该目录,执行以下命令:
- # 安装依赖,使用淘宝资源命令 cnpm
, `9 L& j$ x' s! P - cnpm install# E0 H" H* Z4 o6 v$ ~
) H5 u d8 ]0 ~. x- # 启动应用,地址为 localhost:8080
# Q* K! F' G+ ^3 R( y9 F - cnpm run dev
复制代码 如果你需要发布到正式环境可以执行以下命令:: M8 [" \7 g' f/ T. ~! V: l# s
" P4 C: W, b# P# z; d6 {' l6 B' L Y
3 R9 v6 E4 [! ^; F( Q6 X
# P" _7 R& N. o# i, P
$ U3 R. u1 M; L
% h8 Y! Z, B+ N4 k9 W) S
. ?: c: i/ x2 l; a2 F8 \, J9 Y
# ~+ {( P# @$ ~) S$ C! S/ t1 ~8 D# b7 K+ w
! L4 Q, j5 ] O* }$ ^8 g. b& c2 S( X6 ?9 G
7 @$ Z5 y: F4 w; i" J
-
-
vue-router.js
63.76 KB, 下载次数: 2, 下载积分: 论坛积分 -2 分, 贡献值 -1 个, 好评度 -1 次
-
-
vue-2.0-simple-routing-example-master.zip
6.58 KB, 下载次数: 1, 下载积分: 论坛积分 -2 分, 贡献值 -1 个, 好评度 -1 次
| 欢迎光临 cncml手绘网 (http://www.cncml.com/) |
Powered by Discuz! X3.2 |