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

QQ登录

只需一步,快速开始

 找回密码
 立即注册

QQ登录

只需一步,快速开始

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

[Vue.js] Vue.js 起步

[复制链接]
跳转到指定楼层
楼主
发表于 2018-7-1 23:08:58 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
Vue.js 起步
每个 Vue 应用都需要通过实例化 Vue 来实现。
语法格式如下:
  1. var vm = new Vue({
    : v( D7 H9 r" ^6 K# B6 Z+ x6 C. l
  2.   // 选项( Q9 l; j$ k2 a
  3. })
复制代码
接下来让我们通过实例来看下 Vue 构造器中需要哪些内容:
  1. <div id="vue_det">  z2 e4 A4 X5 S1 w2 o; }1 v
  2.     <h1>site : {{site}}</h1>
    # M. K+ u7 f6 a- J4 T0 E/ g
  3.     <h1>url : {{url}}</h1>
    0 Y# P7 u" Q& L8 u2 _
  4.     <h1>{{details()}}</h1>
    ( y0 r' N* ~- H7 O
  5. </div>& T  n) U% ?3 [2 U- _; p
  6. <script type="text/javascript">* t' \0 m  L- ?" K. _" r
  7.     var vm = new Vue({$ a% P, {3 c3 u/ l) r
  8.         el: '#vue_det',
      G& g, E4 p9 t2 T! d, u) P
  9.         data: {
    - |! Z! _5 p# b& _
  10.             site: "菜鸟教程",
    & f4 {7 E6 n% N3 L1 N7 [. M; M0 g
  11.             url: "www.runoob.com",
    7 D/ B' Z8 N, Z$ x; l) a
  12.             alexa: "10000"
    9 w7 ~1 _- `* v
  13.         },
    5 a8 Y; w9 U7 j9 U
  14.         methods: {: U. X4 @% x- o, U, f
  15.             details: function() {# `" Q" r' @# b* o- Z2 o0 w* f
  16.                 return  this.site + " - 学的不仅是技术,更是梦想!";
    % S: A' C( ?4 W1 ~, O: m) b! d
  17.             }! a' j' p4 \' S$ m. z# m
  18.         }
    + y' y" n+ y; i$ A
  19.     })
    ( Q6 G5 ?: n: r1 V8 {) v
  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">- P2 }8 }' M( p" l1 z6 m& v5 S
  2.     <h1>site : {{site}}</h1>5 g0 V2 p8 `% h5 }5 w- W- N' _
  3.     <h1>url : {{url}}</h1>
    , J/ v; O; P# l: }% \
  4.     <h1>{{details()}}</h1>
    ! p* u$ @; ~& V! k4 g! u4 j, T+ x
  5. </div>
复制代码
当一个 Vue 实例被创建时,它向 Vue 的响应式系统中加入了其 data 对象中能找到的所有的属性。当这些属性的值发生改变时,html 视图将也会产生相应的变化。
  1. <div id="vue_det">+ t! n3 C( b9 E
  2.     <h1>site : {{site}}</h1>4 d6 T; p; K: M
  3.     <h1>url : {{url}}</h1>; i5 @( R# S/ g4 H) _
  4.     <h1>Alexa : {{alexa}}</h1>0 u! J0 a) n8 W8 ?: ]
  5. </div>
    ) o( P/ b2 h: r! Z$ F9 R$ h
  6. <script type="text/javascript">1 g2 H* b4 h6 [' W1 p# W9 P, B5 i
  7. // 我们的数据对象. h( O. i5 {# R" L  n  M
  8. var data = { site: "菜鸟教程", url: "www.runoob.com", alexa: 10000}) V- k! ^% N3 [; h# y
  9. var vm = new Vue({
    % }  L# O! v2 W( ~& ~/ r6 Y. S, f
  10.     el: '#vue_det',
    $ s3 P: C- g9 d/ J; S% s
  11.     data: data
    ' l3 K- u) t  C
  12. })
    : V% a9 {% g! X2 h; E+ a7 x
  13. // 它们引用相同的对象!
    , W3 t5 _* w! }! U! T1 i7 e: }
  14. document.write(vm.a === data.a) // true
    8 @! o& f# X6 w, i* t# M
  15. document.write("<br>")
    ( |, f& I& F0 h
  16. // 设置属性也会影响到原始数据6 V1 f, D# w6 @1 S; B: I
  17. vm.site = "Runoob"
    ! z9 C5 Y( C: \
  18. document.write(data.site + "<br>") // Runoob/ J7 |7 s  ?+ m! g1 q

  19. ) A9 i/ W( w& g& ]7 V7 o1 E
  20. // ……反之亦然+ @" Q* Q7 W6 ]- [# j
  21. data.alexa = 1234
      _1 R( E* O( m7 p
  22. document.write(vm.alexa) // 1234
    . |3 Q8 D( X% u2 A7 {& B2 a/ @0 P1 h
  23. </script>
复制代码
除了数据属性,Vue 实例还提供了一些有用的实例属性与方法。它们都有前缀 $,以便与用户定义的属性区分开来。例如:
  1. <div id="vue_det">
    3 ?4 y7 t8 K' F/ E( S0 @: ~; U
  2.     <h1>site : {{site}}</h1>
    ( ^4 j3 s( Z7 g. P, T+ p9 k
  3.     <h1>url : {{url}}</h1>6 G6 f/ T7 g( F) H* o6 ?
  4.     <h1>Alexa : {{alexa}}</h1>9 _! G5 V7 w7 @9 [& K5 `5 S
  5. </div>/ |7 w- \* g4 {3 f: j
  6. <script type="text/javascript">
    - D' ^' q  l& i% E
  7. // 我们的数据对象$ h: ~# ]# d4 G( ~4 R) F( e
  8. var data = { site: "菜鸟教程", url: "www.runoob.com", alexa: 10000}
    8 R* T; A: U' n! _6 s
  9. var vm = new Vue({3 X+ f7 q5 ]9 p
  10.     el: '#vue_det',
    + m+ U) x7 b5 M- s
  11.     data: data
    # b3 M& w. U. W* h  T  F
  12. })
    5 @* O! P$ C" a" X/ g2 [

  13. . j4 F6 D- }6 ?' d1 o
  14. document.write(vm.$data === data) // true9 [% r2 o; X4 C  ~1 \
  15. document.write("<br>") // true
    & [  J3 i7 T5 t
  16. document.write(vm.$el === document.getElementById('vue_det')) // true) d% U1 r1 H  D5 d
  17. </script>
复制代码

  e- }- n# }2 e, G/ f* I
1 ?/ ]! R$ C+ }
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享分享 支持支持 反对反对
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

GMT+8, 2026-1-30 15:53 , Processed in 0.053566 second(s), 19 queries .

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