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

QQ登录

只需一步,快速开始

 找回密码
 立即注册

QQ登录

只需一步,快速开始

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

[Vue.js] Vue.js 起步

[复制链接]
跳转到指定楼层
楼主
发表于 2018-7-1 23:08:58 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
Vue.js 起步
每个 Vue 应用都需要通过实例化 Vue 来实现。
语法格式如下:
  1. var vm = new Vue({8 ?# I( j7 m% G4 c1 o
  2.   // 选项: j! S" Q; B; h+ j
  3. })
复制代码
接下来让我们通过实例来看下 Vue 构造器中需要哪些内容:
  1. <div id="vue_det">
    " c2 f% w6 t# W0 `
  2.     <h1>site : {{site}}</h1>& _' h% X/ f( Q2 x
  3.     <h1>url : {{url}}</h1>- }2 C% u* `. ?/ n) G; z
  4.     <h1>{{details()}}</h1>
    ( x# t  S1 i0 w: E1 L: l  {% \
  5. </div>+ c' G) K7 u5 v- G; I( m
  6. <script type="text/javascript">
    * D2 S% Y8 O, |; o
  7.     var vm = new Vue({2 j4 y$ M  r3 P' p1 h
  8.         el: '#vue_det',
    5 T8 o7 ^0 E% \, A: c
  9.         data: {3 g$ Q7 K2 Z- ?- [. @
  10.             site: "菜鸟教程",8 g  O" n4 X8 r* e9 K
  11.             url: "www.runoob.com",% Q4 D2 v; I9 Z
  12.             alexa: "10000"
    9 u* P/ F( _: P8 A
  13.         },
    " B. Z  O& e) B7 o5 Z
  14.         methods: {0 h! P( a3 W% O) f8 ]
  15.             details: function() {" M+ ^9 c5 ^% H; T& t" g$ d& {2 d
  16.                 return  this.site + " - 学的不仅是技术,更是梦想!";
    ( s7 I2 o9 P) b( L# ]4 e
  17.             }) e5 A# I# c3 j9 g9 ^2 }
  18.         }: M" N; m& j, [* v' m% B
  19.     }), v9 _( |: h0 c3 w
  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">) B/ {: R* S- g% Q7 y5 e7 m
  2.     <h1>site : {{site}}</h1>% J7 B. r+ B% g8 O" G
  3.     <h1>url : {{url}}</h1>
    # T: C4 H  e- r8 Y' P
  4.     <h1>{{details()}}</h1>
    5 R9 h0 b+ f8 @
  5. </div>
复制代码
当一个 Vue 实例被创建时,它向 Vue 的响应式系统中加入了其 data 对象中能找到的所有的属性。当这些属性的值发生改变时,html 视图将也会产生相应的变化。
  1. <div id="vue_det">1 f4 W( T' w& Q* P( l
  2.     <h1>site : {{site}}</h1>
      W7 x, [0 j& Y( z* ?
  3.     <h1>url : {{url}}</h1>0 h9 ^. O) J4 X3 x" N5 E' E9 L2 _* b
  4.     <h1>Alexa : {{alexa}}</h1>/ @1 F: M$ I4 N5 \
  5. </div>1 e$ {9 C+ I/ K. t
  6. <script type="text/javascript">+ u% w1 C2 N' a2 ]! L9 ?
  7. // 我们的数据对象
    # T. o3 j7 \7 y: Z' [, r
  8. var data = { site: "菜鸟教程", url: "www.runoob.com", alexa: 10000}
    5 K& T4 l& Y5 |# f- m2 L
  9. var vm = new Vue({4 B: p( L' R' Y# F; ]  a3 |( v
  10.     el: '#vue_det',
    5 s' ?# d4 U$ {* ?
  11.     data: data
    ; a3 i0 `- G- K( _
  12. })
    & z" |5 Z; l+ I" R
  13. // 它们引用相同的对象!: [" I! X2 k- p3 ~% |
  14. document.write(vm.a === data.a) // true
      A% L' r6 u+ n6 {/ n( Q" H
  15. document.write("<br>")
    0 |' U9 A% ^+ Q( Q6 V4 y+ [
  16. // 设置属性也会影响到原始数据
    5 @/ P& e  O; P" f( p- \
  17. vm.site = "Runoob"& Z- L& S, R* j$ I$ u
  18. document.write(data.site + "<br>") // Runoob& U$ D8 Y( Q: L3 K+ e5 O: Y

  19. 5 K: v. ~6 r9 ^
  20. // ……反之亦然+ i) K3 N; N1 q1 b# }* }, q
  21. data.alexa = 1234
    & n  L0 e6 _+ b
  22. document.write(vm.alexa) // 1234
    " ~& S0 ?+ o3 v& J) ~
  23. </script>
复制代码
除了数据属性,Vue 实例还提供了一些有用的实例属性与方法。它们都有前缀 $,以便与用户定义的属性区分开来。例如:
  1. <div id="vue_det">/ {5 e& N* I2 u
  2.     <h1>site : {{site}}</h1>! t2 a* v& T7 Z& W/ y  j
  3.     <h1>url : {{url}}</h1>8 _) A3 t/ m3 T3 [+ g& C
  4.     <h1>Alexa : {{alexa}}</h1>6 E: h7 ]8 r0 N& r. X6 ]
  5. </div>
    8 `3 ?- x7 x& @7 C* [' X& C# l
  6. <script type="text/javascript">
    ; b: R2 [1 j2 S& R4 d
  7. // 我们的数据对象! e3 C" @% s* B6 H1 E" w( F
  8. var data = { site: "菜鸟教程", url: "www.runoob.com", alexa: 10000}( K" O$ J2 m+ l5 }. X. |/ @+ a
  9. var vm = new Vue({
    ! w& D4 W0 Z6 \. R  `# G
  10.     el: '#vue_det',
    4 ?2 ^  P4 |: Y7 K4 X! k$ m/ Z
  11.     data: data
    6 u  L/ V& ]4 r% r0 t
  12. })
    ) V; h9 T( `0 e5 t3 c' A
  13. $ ?. K. m5 z- J0 n; [/ S# `: h  r
  14. document.write(vm.$data === data) // true
    % p2 V( M. s( z
  15. document.write("<br>") // true
    " H& a  C) [5 {7 V+ M, G
  16. document.write(vm.$el === document.getElementById('vue_det')) // true
    7 Q6 n! n' r% l8 G) h* L
  17. </script>
复制代码
3 i3 Y7 V2 @3 ]  o
3 w( V+ J! e7 D: N7 T3 P
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享分享 支持支持 反对反对
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

GMT+8, 2026-4-30 19:02 , Processed in 0.057235 second(s), 19 queries .

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