您尚未登录,请登录后浏览更多内容! 登录 | 立即注册

QQ登录

只需一步,快速开始

 找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 15479|回复: 0
打印 上一主题 下一主题

[Vue.js] Vue.js 路由

[复制链接]
跳转到指定楼层
楼主
发表于 2018-7-4 11:44:03 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
本章节我们将为大家介绍 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
复制代码
- A0 n9 U; R  s7 S
游客,本帖隐藏的内容需要积分高于 1 才可浏览,您当前积分为 0

! W8 E9 Z3 f# n1 FNPM
推荐使用淘宝镜像:
  1. cnpm install vue-router
复制代码
简单实例
Vue.js + vue-router 可以很简单的实现单页应用。
以下实例中我们将 vue-router 加进来,然后配置组件和路由映射,再告诉 vue-router 在哪里渲染它们。代码如下所示:
HTML 代码3 F" W2 T( B5 N  w
  1. <script src="https://unpkg.com/vue/dist/vue.js"></script>
    , m0 B' g9 s, \! e8 c# E9 u& |
  2. <script src="https://unpkg.com/vue-router/dist/vue-router.js"></script>  k6 @# \4 b# o0 s# }/ ^: H- c; F

  3. 9 w) L# @" T; f% X# R
  4. <div id="app">
    9 z7 I$ \4 V" t; h: A1 _: L) C- l
  5.   <h1>Hello App!</h1>% N- H* K  B1 f6 x
  6.   <p>
    ! I0 P/ @( [0 c" \  v
  7.     <!-- 使用 router-link 组件来导航. -->0 R6 e; `4 j  t1 n* ~# R& x1 L+ l$ o+ w
  8.     <!-- 通过传入 `to` 属性指定链接. -->) u' y, z& d8 p  L3 h
  9.     <!-- <router-link> 默认会被渲染成一个 `<a>` 标签 -->
    ' @/ S3 m% E$ M
  10.     <router-link to="/foo">Go to Foo</router-link>
    8 b  T8 X8 D( K# `! F5 J) Q* c
  11.     <router-link to="/bar">Go to Bar</router-link>
    " G+ D6 ?# ~( z7 ^
  12.   </p>
    : \. `; b) t5 Z
  13.   <!-- 路由出口 -->1 ?3 m7 n5 e4 V2 m5 \2 d
  14.   <!-- 路由匹配到的组件将渲染在这里 -->. y8 v7 B( D: n* `/ r1 H; o
  15.   <router-view></router-view>
    0 T4 {) Q) A7 d# @* u  y! Z" S8 l# O
  16. </div>
复制代码
JavaScript 代码
  1. // 0. 如果使用模块化机制编程,導入Vue和VueRouter,要调用 Vue.use(VueRouter)
    # K. r* S) w) _

  2. 0 u2 l9 J4 M/ D7 q2 V" d" p
  3. // 1. 定义(路由)组件。+ W4 `2 C2 P3 M  a6 u/ J
  4. // 可以从其他文件 import 进来4 p: t% Y; g' R/ q2 W  j# t% Z; \( i
  5. const Foo = { template: '<div>foo</div>' }
      g( c* L9 D4 |% s" A! U% H6 ~3 o
  6. const Bar = { template: '<div>bar</div>' }9 s0 C+ @. l% D4 \; l

  7. * {# a# r% |1 Y$ O
  8. // 2. 定义路由! }) Y" m. y1 V1 r2 `( {
  9. // 每个路由应该映射一个组件。 其中"component" 可以是+ `5 R8 f: j4 J# u* t3 h
  10. // 通过 Vue.extend() 创建的组件构造器,
    ) a2 p0 }0 {+ F4 f+ G. M, e+ Z
  11. // 或者,只是一个组件配置对象。+ L5 \! w7 p+ b& J
  12. // 我们晚点再讨论嵌套路由。7 c' g$ a- W6 g( b  i0 X) E( ]- \
  13. const routes = [
    3 y6 p: o6 t& U
  14.   { path: '/foo', component: Foo },
    * E+ _; n3 B" A9 Q- s7 Z
  15.   { path: '/bar', component: Bar }% Z8 n6 b5 P% c% [0 n
  16. ]- z+ q1 I" F5 _9 E, `& q

  17. 5 {$ h  w, n& @0 n+ d
  18. // 3. 创建 router 实例,然后传 `routes` 配置
    / a7 o7 c: b* t$ D7 `& k5 N9 H' J
  19. // 你还可以传别的配置参数, 不过先这么简单着吧。
    3 Q; e: u: l; D: f; R! o
  20. const router = new VueRouter({! X$ z' w  |5 |( x. a
  21.   routes // (缩写)相当于 routes: routes
    / r1 Q8 s5 e' ?) r
  22. })
    5 M" o6 r6 m! {; R, Z% s  \( g) |

  23. 2 ~6 b6 s5 L8 o
  24. // 4. 创建和挂载根实例。( W: e2 q6 x4 P& o9 r6 [) Y0 Q: j
  25. // 记得要通过 router 配置参数注入路由,
    * E9 F2 p' R! [' h- W7 v! ~, E
  26. // 从而让整个应用都有路由功能
    # k- T7 e: U+ j; S
  27. const app = new Vue({4 V/ f( I9 D! \4 n3 B/ j
  28.   router9 z5 F& q* }7 j2 R& U
  29. }).$mount('#app')5 z' P! o0 p1 b0 t# u" j
  30. 1 m" ^9 d; {$ S, z7 \
  31. // 现在,应用已经启动了!
复制代码
NPM 路由实例
接下来我们演示了一个使用 npm 简单的路由实例,开始前,请先下载该实例源代码:
游客,本帖隐藏的内容需要积分高于 1 才可浏览,您当前积分为 0

; t- \- }  B* _+ Q
下载完后,解压该目录,重命名目录为 vue-demo,vu 并进入该目录,执行以下命令:
  1. # 安装依赖,使用淘宝资源命令 cnpm) `/ A; p4 l6 ^: V4 n- _
  2. cnpm install; R2 _; V9 ~8 T$ o
  3. 8 X  M: I- M% [. L8 q3 `" N
  4. # 启动应用,地址为 localhost:8080: W) l. U6 P/ H" ^$ V7 I
  5. cnpm run dev
复制代码
如果你需要发布到正式环境可以执行以下命令:
, G/ N0 N: _8 Q' o
  1. cnpm run build
复制代码

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
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享分享 支持支持 反对反对
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

GMT+8, 2026-1-30 14:28 , Processed in 0.058627 second(s), 23 queries .

Copyright © 2001-2026 Powered by cncml! X3.2. Theme By cncml!