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

QQ登录

只需一步,快速开始

 找回密码
 立即注册

QQ登录

只需一步,快速开始

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

[Vue.js] Vue.js 起步

[复制链接]
跳转到指定楼层
楼主
发表于 2018-7-1 23:08:58 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
Vue.js 起步
每个 Vue 应用都需要通过实例化 Vue 来实现。
语法格式如下:
  1. var vm = new Vue({% X  j, T/ G% s$ P# G& |
  2.   // 选项5 L  i2 M- Q' D" ?4 H1 U. D# u
  3. })
复制代码
接下来让我们通过实例来看下 Vue 构造器中需要哪些内容:
  1. <div id="vue_det">
    8 }4 S3 ^; h/ f5 O* Y0 [
  2.     <h1>site : {{site}}</h1>+ x! O% t4 l, L2 m; N- V: b2 Y, a
  3.     <h1>url : {{url}}</h1>
    1 h' j8 Q+ A, r3 Z# u
  4.     <h1>{{details()}}</h1>/ q- d' b4 b& \/ H4 s+ j- Q* E' Y& V, g
  5. </div>
    : R5 s# q8 v. w, s% P5 S  e$ r
  6. <script type="text/javascript">& J% j4 }' y  \# A! ^
  7.     var vm = new Vue({! s+ z7 y( Y! Y0 A7 B  _
  8.         el: '#vue_det',
    ! \. c- d! b+ }+ q; q4 y3 t" Q
  9.         data: {! D" z' n* F" t% ~) f. u2 b
  10.             site: "菜鸟教程",
    9 s+ e3 k% o; G: `0 X# g
  11.             url: "www.runoob.com",4 d: M( l7 d  W2 _6 v& N6 n
  12.             alexa: "10000"
    ( A; N9 X/ a+ L+ z, c6 g" H1 W# y; ]
  13.         },
    % b* y" D7 N( A. \
  14.         methods: {
    # p" G( M3 O6 w; }# p8 W' m* W, F
  15.             details: function() {
    $ d! g: L2 b4 U- `8 V( }* v
  16.                 return  this.site + " - 学的不仅是技术,更是梦想!";! D* a% d& _. o
  17.             }; m8 y7 Q( x$ z4 {
  18.         }
    , g- K0 l" L5 R# p- h: {% u7 L- i
  19.     })  Z* _% w6 _$ ?- c& c
  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">
    + N  q, r  z6 t+ K" F
  2.     <h1>site : {{site}}</h1>
    & D1 ?9 k. l: |/ ~7 i+ ~
  3.     <h1>url : {{url}}</h1>
    ) W7 S; T; ^1 S/ _8 M; q  F
  4.     <h1>{{details()}}</h1>; B  s# ^2 k3 D$ z& r, p1 B
  5. </div>
复制代码
当一个 Vue 实例被创建时,它向 Vue 的响应式系统中加入了其 data 对象中能找到的所有的属性。当这些属性的值发生改变时,html 视图将也会产生相应的变化。
  1. <div id="vue_det">
    " E$ h, ?8 a$ \7 Q+ _. K$ I3 O
  2.     <h1>site : {{site}}</h1>
    + x; ~; |/ @2 l0 D# S
  3.     <h1>url : {{url}}</h1>7 q/ g0 p5 e" i( P1 n
  4.     <h1>Alexa : {{alexa}}</h1>- N2 V. Y1 W  F0 \$ X+ |
  5. </div>
    ) R" r% K5 W5 A# _
  6. <script type="text/javascript">! _0 w* x3 V8 b" p
  7. // 我们的数据对象
    * D5 b0 O9 Z, Y# W% c
  8. var data = { site: "菜鸟教程", url: "www.runoob.com", alexa: 10000}
    ! I+ b+ F& l' ]& ~) t
  9. var vm = new Vue({/ H: H# M6 E5 \0 D) c% b3 d
  10.     el: '#vue_det',  s- ]. a" E! J" R+ s, A
  11.     data: data% p, R3 \2 T% k$ A3 m. D* }
  12. })) Y8 H- ?8 U/ Y9 g, B
  13. // 它们引用相同的对象!" P* U  }+ t. A
  14. document.write(vm.a === data.a) // true
    % k$ H+ `; ^0 T# p1 |- M
  15. document.write("<br>")
    5 d6 j/ @0 K2 y8 }
  16. // 设置属性也会影响到原始数据$ d7 G8 h/ v, K. p
  17. vm.site = "Runoob"
    0 B/ x! R& e5 D! q
  18. document.write(data.site + "<br>") // Runoob  b6 Y' Q; t" [# r" V$ G

  19. 5 D' [. h7 ~- ?- x" e4 R1 p8 e
  20. // ……反之亦然& y& d6 n  t/ u. T: \7 d
  21. data.alexa = 1234, ^' C, w: a0 h" _$ ~* C# [7 C
  22. document.write(vm.alexa) // 12340 F, i6 H8 l  q/ j* l2 z3 ~
  23. </script>
复制代码
除了数据属性,Vue 实例还提供了一些有用的实例属性与方法。它们都有前缀 $,以便与用户定义的属性区分开来。例如:
  1. <div id="vue_det">
    - _9 i$ x. J+ _# V1 V
  2.     <h1>site : {{site}}</h1>3 j" _' L0 Q7 S2 Y! X- _" e! w
  3.     <h1>url : {{url}}</h1>
    . r/ a( H) ]* a* ]3 K4 q
  4.     <h1>Alexa : {{alexa}}</h1>
    . r' y$ t) K' q  ~$ d
  5. </div>
    ; }4 U/ y% G3 B
  6. <script type="text/javascript">
    3 U# _4 N, ^7 l2 S: E& H2 V
  7. // 我们的数据对象' ~! C0 w- D5 J1 M) a% @
  8. var data = { site: "菜鸟教程", url: "www.runoob.com", alexa: 10000}
    , R. ^$ {, w! }8 g3 I/ K, m8 v9 }
  9. var vm = new Vue({- ~" c' W( S* y; N) Y, V
  10.     el: '#vue_det',
    8 m6 A5 D* L4 w, P! L
  11.     data: data" O- ~6 {0 Y1 k! z4 h  K
  12. })& L/ w9 W  O( Q
  13. 0 W, M* y% l( T8 J
  14. document.write(vm.$data === data) // true# J) O8 U- T( U$ X( y
  15. document.write("<br>") // true$ E2 v0 L- O9 \% H; n( c2 ^
  16. document.write(vm.$el === document.getElementById('vue_det')) // true1 \2 O$ C6 a9 t- T7 s
  17. </script>
复制代码
# g! X6 {( @( u: y( y% Q# h

( e8 }$ j  v) L1 W
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享分享 支持支持 反对反对
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

GMT+8, 2024-12-22 12:09 , Processed in 0.120835 second(s), 19 queries .

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