cncml手绘网

标题: Vue.js 路由 [打印本页]

作者: admin    时间: 2018-7-4 11:44
标题: Vue.js 路由
本章节我们将为大家介绍 Vue.js 路由。
Vue.js 路由允许我们通过不同的 URL 访问不同的内容。
通过 Vue.js 可以实现多视图的单页Web应用(single page web application,SPA)。
Vue.js 路由需要载入 vue-router 库
中文文档地址:vue-router文档

安装1、直接下载 / CDN
  1. https://unpkg.com/vue-router/dist/vue-router.js
复制代码
; R7 q) D, k1 D+ q

0 I- d5 D" ~& T9 e% G5 nNPM
推荐使用淘宝镜像:
  1. cnpm install vue-router
复制代码
简单实例
Vue.js + vue-router 可以很简单的实现单页应用。
以下实例中我们将 vue-router 加进来,然后配置组件和路由映射,再告诉 vue-router 在哪里渲染它们。代码如下所示:
HTML 代码
3 u& A# m+ j3 t$ r
  1. <script src="https://unpkg.com/vue/dist/vue.js"></script>3 e4 D6 z3 Z" S0 }! r
  2. <script src="https://unpkg.com/vue-router/dist/vue-router.js"></script>
    - H1 A2 g3 E; ]. W5 z6 h8 `
  3. 0 {' e0 X6 Y" ^
  4. <div id="app">7 u. Q& G0 |) N0 D
  5.   <h1>Hello App!</h1>& o# y9 @; N; T' T
  6.   <p>" C, {) i, S/ D* [. @( d
  7.     <!-- 使用 router-link 组件来导航. -->* Z, z) x; g! l, M4 A- ~5 a: a
  8.     <!-- 通过传入 `to` 属性指定链接. -->* C  V7 L9 h1 `8 K% z
  9.     <!-- <router-link> 默认会被渲染成一个 `<a>` 标签 -->
    ! n$ o8 ?+ l8 u
  10.     <router-link to="/foo">Go to Foo</router-link>4 }, |$ ~2 I; {  Y& L) l
  11.     <router-link to="/bar">Go to Bar</router-link>! k9 n8 D) |4 L& G, p
  12.   </p>
    7 b- M; }1 @, O! F# }; f8 {7 _
  13.   <!-- 路由出口 -->0 V) u2 k# f+ p6 `. s
  14.   <!-- 路由匹配到的组件将渲染在这里 -->9 o. k5 _2 W/ W5 N
  15.   <router-view></router-view>
    & ?, }3 A, q. N- Z+ p. R- u( _
  16. </div>
复制代码
JavaScript 代码
  1. // 0. 如果使用模块化机制编程,導入Vue和VueRouter,要调用 Vue.use(VueRouter)9 b/ g& s6 b; y

  2. 5 f/ {- e7 i6 J$ i; }9 h
  3. // 1. 定义(路由)组件。/ P' R/ B( Y. A& {) m, e1 t
  4. // 可以从其他文件 import 进来) X7 v; {2 E. w' f
  5. const Foo = { template: '<div>foo</div>' }
    # K1 E* v6 S2 \' O$ ~2 j# {$ \4 b  U* |
  6. const Bar = { template: '<div>bar</div>' }* o1 Y$ M0 @0 }6 y% ?; k2 m  \/ }
  7. 9 f5 }3 y- K; w9 ?; ]" ?4 N" R
  8. // 2. 定义路由+ o  u5 ]2 d" Y  v' f
  9. // 每个路由应该映射一个组件。 其中"component" 可以是
    # Y# N$ K3 M* p4 |
  10. // 通过 Vue.extend() 创建的组件构造器,/ I- j+ Z6 D" {! J; a8 e) d
  11. // 或者,只是一个组件配置对象。
    - R6 C, W: H) U% ]# Q
  12. // 我们晚点再讨论嵌套路由。
    - o, s9 w4 m& i$ o2 V& v
  13. const routes = [
    % @& ^: ]0 u2 k1 m& N
  14.   { path: '/foo', component: Foo },
    : q; L' z% y- E* }6 E: Y' V/ S+ c
  15.   { path: '/bar', component: Bar }( {- w' G! h, f( |. i7 t
  16. ]( ~' }; r1 v; z/ A6 q# D5 ~
  17. . t1 Y) x9 N9 p$ C- A. C
  18. // 3. 创建 router 实例,然后传 `routes` 配置
    - ^4 P9 ~8 G3 r' h
  19. // 你还可以传别的配置参数, 不过先这么简单着吧。, ~0 i2 O. j, [" v. h9 y( u* Y
  20. const router = new VueRouter({
    + K8 y; K% Z" w0 g! c. i* q
  21.   routes // (缩写)相当于 routes: routes/ @7 `& [* n( ]3 a) |
  22. })2 F, r; ?4 l, \2 H

  23. ' C& m0 C9 n  {; G/ l1 f/ S
  24. // 4. 创建和挂载根实例。/ x# H5 x: S0 E# d2 N- F6 Q
  25. // 记得要通过 router 配置参数注入路由,
    6 W0 j; `3 {3 D' [
  26. // 从而让整个应用都有路由功能
    ) B/ p: U3 Y6 B. N8 F" e* n
  27. const app = new Vue({
    . }0 x! ]. U5 u
  28.   router4 t' O/ r( E& \8 B5 K3 N9 z: n
  29. }).$mount('#app'); F0 Y  U3 m7 H0 l

  30. ( p6 V1 H. j& m0 ]5 g
  31. // 现在,应用已经启动了!
复制代码
NPM 路由实例
接下来我们演示了一个使用 npm 简单的路由实例,开始前,请先下载该实例源代码:
/ X  O' e) T9 V
你也可以在 Github 上下载:https://github.com/chrisvfritz/vue-2.0-simple-routing-example
下载完后,解压该目录,重命名目录为 vue-demo,vu 并进入该目录,执行以下命令:
  1. # 安装依赖,使用淘宝资源命令 cnpm
    , `9 L& j$ x' s! P
  2. cnpm install# E0 H" H* Z4 o6 v$ ~

  3. ) H5 u  d8 ]0 ~. x
  4. # 启动应用,地址为 localhost:8080
    # Q* K! F' G+ ^3 R( y9 F
  5. cnpm run dev
复制代码
如果你需要发布到正式环境可以执行以下命令:: M8 [" \7 g' f/ T. ~! V: l# s
  1. cnpm run build
复制代码
" 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