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

QQ登录

只需一步,快速开始

 找回密码
 立即注册

QQ登录

只需一步,快速开始

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

[Vue.js] Vue.js 起步

[复制链接]
跳转到指定楼层
楼主
发表于 2018-7-1 23:08:58 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
Vue.js 起步
每个 Vue 应用都需要通过实例化 Vue 来实现。
语法格式如下:
  1. var vm = new Vue({
    $ P( h! b, j; H+ w1 C
  2.   // 选项
    ! N& E! B* c' t  C4 A
  3. })
复制代码
接下来让我们通过实例来看下 Vue 构造器中需要哪些内容:
  1. <div id="vue_det">0 p4 D0 ^1 d3 N+ N4 ^: R& W, X$ |
  2.     <h1>site : {{site}}</h1>* c, O; O1 }' F* d1 I
  3.     <h1>url : {{url}}</h1>
    ! t" k5 n- i4 b8 Z# w
  4.     <h1>{{details()}}</h1>
    + i- P7 W2 N3 X% n' e9 y2 \% _$ a
  5. </div>+ D  K" e( W+ B( l6 N9 V. N# P6 D
  6. <script type="text/javascript">
    # E: |9 q/ S" x+ l) V. H
  7.     var vm = new Vue({" |8 F) ~: P7 P
  8.         el: '#vue_det',
      O" m7 y1 E" t8 Z3 u. l
  9.         data: {% N8 @  _6 o* V6 p
  10.             site: "菜鸟教程",% }( x! W/ F7 }
  11.             url: "www.runoob.com",  {6 n* S. Z/ a  i+ A6 q: c
  12.             alexa: "10000"
    + e/ t/ G. n; x0 e
  13.         },
    & f+ \. y8 g( F* I; O5 z0 Q
  14.         methods: {) c5 B1 G( k9 k( d$ j0 L
  15.             details: function() {2 [7 e: {! P$ {% c3 b
  16.                 return  this.site + " - 学的不仅是技术,更是梦想!";
    ! `5 X; b% d6 @1 h: j4 t
  17.             }
    7 q( b" }. }6 s6 d2 j' K& v; }  G
  18.         }
    & g+ {9 k& c& w/ J, `! L/ J( \0 o- \
  19.     })" o7 w6 t, ]: X# a& f
  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">' C. z4 F! r3 {5 C8 Q7 K! f5 y
  2.     <h1>site : {{site}}</h1>
    + t% ^2 k7 q/ f3 ?5 w
  3.     <h1>url : {{url}}</h1>! s% G, E& Y3 R' f6 o  J  d
  4.     <h1>{{details()}}</h1>% J$ H& k4 R  S+ d2 J: H  O
  5. </div>
复制代码
当一个 Vue 实例被创建时,它向 Vue 的响应式系统中加入了其 data 对象中能找到的所有的属性。当这些属性的值发生改变时,html 视图将也会产生相应的变化。
  1. <div id="vue_det">9 A( E, H$ R% V, k8 N
  2.     <h1>site : {{site}}</h1>
    9 j% w+ o2 u, V3 e+ `2 I) [
  3.     <h1>url : {{url}}</h1>
    8 m* D% P' q3 u9 k8 ?& K- E! ^
  4.     <h1>Alexa : {{alexa}}</h1>6 H2 n$ z4 O& V. k/ b! r
  5. </div>5 {, P$ H, G$ ?/ h2 A
  6. <script type="text/javascript">
    8 [5 w( C- V- |( \% V# |
  7. // 我们的数据对象2 {/ g( [- m0 @8 L. y8 ]
  8. var data = { site: "菜鸟教程", url: "www.runoob.com", alexa: 10000}
    7 i* M7 I9 J( X
  9. var vm = new Vue({, _/ S. k; y+ o% T1 @
  10.     el: '#vue_det',
    ! Y# [8 y5 ?6 v6 K" e$ t* R/ B( W
  11.     data: data3 a$ K+ t' j: f! ~
  12. })' j& E9 t% [) V
  13. // 它们引用相同的对象!
    1 C5 `2 f: y+ _# E- j
  14. document.write(vm.a === data.a) // true! P$ u2 _; y, h  B
  15. document.write("<br>")
    ; \- S8 `  U  H9 K, |
  16. // 设置属性也会影响到原始数据
    ' R3 i- ^6 f- T7 R) T! V- }$ Q
  17. vm.site = "Runoob"3 Y" B* u0 t, l
  18. document.write(data.site + "<br>") // Runoob
    ; e4 a* p; Q" U! A+ ^9 o

  19. 0 m1 \) }  w1 n/ G0 d9 J% i& F. j
  20. // ……反之亦然: W# G" N! n& @9 ^! J5 R
  21. data.alexa = 1234* p) D7 m3 w, d: L0 M
  22. document.write(vm.alexa) // 12341 c3 H5 Y0 N3 o; D+ S# {0 ?) y% G# a
  23. </script>
复制代码
除了数据属性,Vue 实例还提供了一些有用的实例属性与方法。它们都有前缀 $,以便与用户定义的属性区分开来。例如:
  1. <div id="vue_det">
    1 i# u9 V* H* V. w
  2.     <h1>site : {{site}}</h1>
    ! a9 j. p9 Q& a: m
  3.     <h1>url : {{url}}</h1>- ^+ H3 N& e  {+ A* \
  4.     <h1>Alexa : {{alexa}}</h1>
    $ d: L5 V; o5 U3 z9 y
  5. </div>- J8 u1 u% W) W/ O3 q3 J
  6. <script type="text/javascript">
    3 c9 q8 j- S7 Z. M1 @7 u; M/ n3 U# ]7 T
  7. // 我们的数据对象2 A5 _1 F2 k& `7 m3 j& d
  8. var data = { site: "菜鸟教程", url: "www.runoob.com", alexa: 10000}/ W: [% y, ?5 U; i
  9. var vm = new Vue({
    ' q$ x# K; W- b  l. q, e( x& z
  10.     el: '#vue_det',! O) b0 r) l% V( Y7 D& z
  11.     data: data
    * ]) k' ~7 X7 d2 ^+ U0 t! ~8 j
  12. }): J9 n* O& w# M+ t0 W

  13. ! \/ c8 M1 A) M8 f( v# c/ I, p
  14. document.write(vm.$data === data) // true
    ! k# g8 A2 v; P  `$ N1 w+ N
  15. document.write("<br>") // true; f, P/ I* N' `! z5 t
  16. document.write(vm.$el === document.getElementById('vue_det')) // true# U; A4 w# }( \. f
  17. </script>
复制代码

5 F' z8 s) i8 Q" y$ F- a! X; @) |) e7 Y6 o5 C) A) k. `1 s
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享分享 支持支持 反对反对
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

GMT+8, 2024-12-22 15:56 , Processed in 0.127047 second(s), 22 queries .

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