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

QQ登录

只需一步,快速开始

 找回密码
 立即注册

QQ登录

只需一步,快速开始

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

[Vue.js] Vue.js 起步

[复制链接]
跳转到指定楼层
楼主
发表于 2018-7-1 23:08:58 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
Vue.js 起步
每个 Vue 应用都需要通过实例化 Vue 来实现。
语法格式如下:
  1. var vm = new Vue({
    ; {' _' \1 D) P- I: K; k
  2.   // 选项
    / f1 @& }" l5 U: b9 ^- s4 R  D; u& d
  3. })
复制代码
接下来让我们通过实例来看下 Vue 构造器中需要哪些内容:
  1. <div id="vue_det">' T0 Y/ U* G' i+ G% {) Y% O, T
  2.     <h1>site : {{site}}</h1>$ x, L; }7 A6 S) m5 }, N
  3.     <h1>url : {{url}}</h1>3 z, ?7 V1 Z5 V* F% B
  4.     <h1>{{details()}}</h1>
    + H$ x  b" T; X! ~0 R
  5. </div>
    0 I3 s; q2 C' O$ I" l1 U
  6. <script type="text/javascript">1 M, K+ X2 ?$ o/ q0 F. M
  7.     var vm = new Vue({1 [1 ~1 ^. }( {" o# P0 l
  8.         el: '#vue_det',
    ) Z! z8 ?) k$ }! \9 i
  9.         data: {
      U, x! V  Q7 k% F# F
  10.             site: "菜鸟教程",
    % l, r9 {2 x* w' L8 t. ~
  11.             url: "www.runoob.com",  T# T3 [, d: Y: l- F* {
  12.             alexa: "10000"
    : K0 c6 s! n1 J8 J: e
  13.         },
    , ?0 o  R  f) K- F6 \: G- B, t' i
  14.         methods: {
    . |2 V/ c( |) _. P& {; r1 A0 \+ k8 C! |
  15.             details: function() {3 w' u/ G3 Q) q, r# }# c1 _% p
  16.                 return  this.site + " - 学的不仅是技术,更是梦想!";
    & x; M  k1 F+ t8 O) U: B
  17.             }
    2 O8 d  ]4 A5 }: U2 F' X
  18.         }* {  I+ \6 Z8 I1 ^$ _
  19.     })
    8 G) _* A/ s1 R/ s
  20. </script>
复制代码
可以看到在 Vue 构造器中有一个el 参数,它是 DOM 元素中的 id。在上面实例中 id 为 vue_det,在 div 元素中:
  1. <div id = "vue_det"></div>
复制代码
这意味着我们接下来的改动全部在以上指定的 div 内,div 外部不受影响。
接下来我们看看如何定义数据对象。
data 用于定义属性,实例中有三个属性分别为:site、url、alexa。
methods 用于定义的函数,可以通过 return 来返回函数值。
{{ }} 用于输出对象属性和函数返回值。
  1. <div id="vue_det">
    : Y3 i( d. w. z/ N4 i
  2.     <h1>site : {{site}}</h1>
    / M! A! F" q( s% r. Y
  3.     <h1>url : {{url}}</h1>
    6 \% }. |2 u  v7 F% c7 O( N
  4.     <h1>{{details()}}</h1>
    : t* Y& p3 Y: A$ O
  5. </div>
复制代码
当一个 Vue 实例被创建时,它向 Vue 的响应式系统中加入了其 data 对象中能找到的所有的属性。当这些属性的值发生改变时,html 视图将也会产生相应的变化。
  1. <div id="vue_det">
    - ?5 D% N/ y' t; s
  2.     <h1>site : {{site}}</h1>$ m! l: m. O0 U
  3.     <h1>url : {{url}}</h1>% {& o' \# `/ M2 ?
  4.     <h1>Alexa : {{alexa}}</h1>0 `% w8 [% Q7 @
  5. </div>. ^$ t+ l# L* T$ o' o
  6. <script type="text/javascript">
    ) W% k& ?7 x% j4 d9 D
  7. // 我们的数据对象
    , N$ ?& r; t- R9 P
  8. var data = { site: "菜鸟教程", url: "www.runoob.com", alexa: 10000}
    " l8 ?. ~/ s; w* |
  9. var vm = new Vue({
    # _: ~+ e/ S) j+ K: d
  10.     el: '#vue_det',
    : _: ~5 c7 E/ z
  11.     data: data) T. [& {& Q% v% n. v# W* r" D$ F
  12. })% o& ]* X& W& b0 B9 ~# L' u1 J3 `
  13. // 它们引用相同的对象!
      L9 f: u8 l: \. j  d' [
  14. document.write(vm.a === data.a) // true1 I- h+ j# V, M+ L* p4 c
  15. document.write("<br>")1 D' L  _; H' p; \
  16. // 设置属性也会影响到原始数据
    % V2 b  }, d6 G1 F  ~
  17. vm.site = "Runoob"
    + ]  n# C% |. `! U
  18. document.write(data.site + "<br>") // Runoob
    $ @6 [0 E" J+ G4 D0 z7 x. ~
  19. 9 |  }( l% G4 `
  20. // ……反之亦然0 P+ s0 f( T$ W& B3 b' q
  21. data.alexa = 1234
    9 G" A6 ~7 J+ Y; _( W
  22. document.write(vm.alexa) // 1234
    % j- p0 T. B: ~2 G4 m7 t
  23. </script>
复制代码
除了数据属性,Vue 实例还提供了一些有用的实例属性与方法。它们都有前缀 $,以便与用户定义的属性区分开来。例如:
  1. <div id="vue_det">! Z! n; _' W& x' K/ J
  2.     <h1>site : {{site}}</h1>: H& e2 N/ i- \) v5 B( U
  3.     <h1>url : {{url}}</h1>
    ; C: d3 A, l& _, q  E# h5 b
  4.     <h1>Alexa : {{alexa}}</h1>
    0 L, ]+ Y. m) D1 P6 V
  5. </div>
    # I/ }. {4 ^% ~  r) A1 Z
  6. <script type="text/javascript">9 o( _" n8 J3 a/ ]
  7. // 我们的数据对象$ T) E7 [8 q8 R/ u
  8. var data = { site: "菜鸟教程", url: "www.runoob.com", alexa: 10000}
    2 h& {/ f4 n5 O& E! i( A
  9. var vm = new Vue({
    $ m  `+ r5 S7 ]" A
  10.     el: '#vue_det',5 D" i4 U1 F/ B
  11.     data: data
    4 K- D5 {; q. ~$ ^
  12. })
    6 e. c) Y. V9 i( U" S1 Q

  13. ( e( \% M* o3 I) T
  14. document.write(vm.$data === data) // true* D8 Z$ Q& u; w0 H9 F) _7 A
  15. document.write("<br>") // true% n5 X# |+ L$ [% J  M  b0 x: K
  16. document.write(vm.$el === document.getElementById('vue_det')) // true; C  L. U! j0 T& l* t2 x
  17. </script>
复制代码

- X6 {9 i' \  _6 B$ g" \& Q* Y& ]3 V2 \/ T
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享分享 支持支持 反对反对
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

GMT+8, 2026-1-30 18:02 , Processed in 0.048151 second(s), 19 queries .

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