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

QQ登录

只需一步,快速开始

 找回密码
 立即注册

QQ登录

只需一步,快速开始

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

[Vue.js] Vue.js 起步

[复制链接]
跳转到指定楼层
楼主
发表于 2018-7-1 23:08:58 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
Vue.js 起步
每个 Vue 应用都需要通过实例化 Vue 来实现。
语法格式如下:
  1. var vm = new Vue({1 w( _$ O' H5 E2 H5 Z" V- Y8 @0 o
  2.   // 选项
    7 L' [) h9 X5 ^& V% I7 E
  3. })
复制代码
接下来让我们通过实例来看下 Vue 构造器中需要哪些内容:
  1. <div id="vue_det">
      O, I$ o/ S5 ?+ E. j2 o( Z
  2.     <h1>site : {{site}}</h1>2 t9 _) B' S* _
  3.     <h1>url : {{url}}</h1>+ ^3 q3 k$ d' j8 s1 P' Q% J
  4.     <h1>{{details()}}</h1>+ @) \, Y6 i: ^' n
  5. </div>0 [4 {$ I" j: Q. X  \+ M0 ]. L
  6. <script type="text/javascript">! w# w. m9 _' Z7 f$ e
  7.     var vm = new Vue({- k, Y; D  i3 @! Q0 @* i/ p" ~9 \
  8.         el: '#vue_det',
    7 X. J! w, @3 O' @5 h$ \& z
  9.         data: {* Q# D0 H+ i4 h* H: t
  10.             site: "菜鸟教程",
    1 w4 p' X3 G8 f3 s' U' ~0 S
  11.             url: "www.runoob.com",
    % g/ K  B5 p3 x( j3 Y" F' U! @
  12.             alexa: "10000"
    " F6 i) d) Y/ B0 C
  13.         }," i9 X# R$ F$ W- ?0 L/ |
  14.         methods: {
    * g( }6 A; G8 e! ^$ \* M: u( |
  15.             details: function() {1 w5 g7 T$ g3 n
  16.                 return  this.site + " - 学的不仅是技术,更是梦想!";2 i$ z" M. J" N" ^- b
  17.             }- ]4 M" }0 b, ~0 @* _
  18.         }7 F6 Y: X) b& F2 t& W
  19.     })" n6 T5 V4 G  u) c# l; Y+ p$ 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">5 V5 t$ l% K' e# U( J6 Y
  2.     <h1>site : {{site}}</h1>& o' [7 V- P/ Q8 }
  3.     <h1>url : {{url}}</h1>
    6 n8 C" \5 f$ Z; W% E
  4.     <h1>{{details()}}</h1>
    & y$ E; T! ?- n9 f4 Q
  5. </div>
复制代码
当一个 Vue 实例被创建时,它向 Vue 的响应式系统中加入了其 data 对象中能找到的所有的属性。当这些属性的值发生改变时,html 视图将也会产生相应的变化。
  1. <div id="vue_det">& x7 R4 V, A* e. [" }
  2.     <h1>site : {{site}}</h1>
    # \. B) S: W: {" F+ v
  3.     <h1>url : {{url}}</h1>: |5 U' ]# n- U' a/ j: j
  4.     <h1>Alexa : {{alexa}}</h1>. O3 i6 D1 d; E9 O" M+ e
  5. </div>
    ( g) n: f! d0 S. Q/ ^3 d+ j+ u; [
  6. <script type="text/javascript">
    - f0 m7 c5 n4 c, J) b8 Y
  7. // 我们的数据对象+ ]$ o- ^% D9 g1 {2 Q
  8. var data = { site: "菜鸟教程", url: "www.runoob.com", alexa: 10000}3 y* n! F6 s/ t3 }& U
  9. var vm = new Vue({
    " t* {+ Y# V/ r9 ^9 ]
  10.     el: '#vue_det',1 e2 o& q; Y3 B
  11.     data: data4 M) E0 C' Y! v0 a. l8 `5 \
  12. })
    / ^9 X# V# e$ H5 A$ C+ K. A
  13. // 它们引用相同的对象!/ b! J: B; X% Y8 B
  14. document.write(vm.a === data.a) // true1 c; o3 j+ f6 K9 g/ \, T  z3 v
  15. document.write("<br>")
    ; E( c8 l1 N& ]
  16. // 设置属性也会影响到原始数据
    + r- F* I' D5 N) L* I7 r  x
  17. vm.site = "Runoob", r1 ^) e* c. ?4 s; f9 r' A! T& @% o
  18. document.write(data.site + "<br>") // Runoob
    - u+ X/ D. A- G0 ?  p

  19. % I+ U4 a! n0 s" y$ ]
  20. // ……反之亦然
    ! P6 Q# z. @+ e1 X2 z) \) Z& y! g
  21. data.alexa = 1234( x2 G( N% X& @$ N' P
  22. document.write(vm.alexa) // 1234
    - o# k) f$ Y: [7 r# |
  23. </script>
复制代码
除了数据属性,Vue 实例还提供了一些有用的实例属性与方法。它们都有前缀 $,以便与用户定义的属性区分开来。例如:
  1. <div id="vue_det">
    * D+ Q: Q+ U' m
  2.     <h1>site : {{site}}</h1>! U. R$ i! H3 q' T: s4 ]+ q) G
  3.     <h1>url : {{url}}</h1>
    * n2 V* s/ O! J7 M; I  d3 [
  4.     <h1>Alexa : {{alexa}}</h1>
    ; g4 q: b& [! L$ s+ c
  5. </div>
    - C9 [0 N4 p9 p6 H, w
  6. <script type="text/javascript">1 z" ?: Q) _+ c1 e
  7. // 我们的数据对象
    1 F5 M& T! a  t' k9 @3 |6 C
  8. var data = { site: "菜鸟教程", url: "www.runoob.com", alexa: 10000}, K  _) h4 N6 ~. c+ R
  9. var vm = new Vue({
    # T6 k1 g; Y( o
  10.     el: '#vue_det',
    4 [. [2 n0 H$ S5 C# ?) Z. I3 `& v
  11.     data: data7 T% ~1 B- E% c) g) l: _
  12. })
    9 o4 P1 i7 r; R3 I! c4 v$ _5 t( v8 T
  13. ' a" j1 }3 E, s1 Q! @# V  G
  14. document.write(vm.$data === data) // true) H- Y% i* U( d5 g9 @( r
  15. document.write("<br>") // true7 O& B! y/ N6 T1 Q: ~& z( d2 l2 y
  16. document.write(vm.$el === document.getElementById('vue_det')) // true
    / r) X/ s2 c, M; G6 f
  17. </script>
复制代码
! B+ ]1 a1 H) Y2 \' o: K
7 ^/ ?* N1 C! [+ M/ K9 M; ?5 T6 s3 i
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享分享 支持支持 反对反对
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

GMT+8, 2026-3-16 20:14 , Processed in 0.059656 second(s), 19 queries .

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