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

QQ登录

只需一步,快速开始

 找回密码
 立即注册

QQ登录

只需一步,快速开始

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

[Vue.js] Vue.js 起步

[复制链接]
跳转到指定楼层
楼主
发表于 2018-7-1 23:08:58 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
Vue.js 起步
每个 Vue 应用都需要通过实例化 Vue 来实现。
语法格式如下:
  1. var vm = new Vue({
    5 t/ h+ C" [+ f
  2.   // 选项
    # b  ]2 A6 W1 a
  3. })
复制代码
接下来让我们通过实例来看下 Vue 构造器中需要哪些内容:
  1. <div id="vue_det">* D5 b* i% O" c* L. x4 U2 ^* }7 F: s
  2.     <h1>site : {{site}}</h1>7 g! c+ s4 T0 M% |
  3.     <h1>url : {{url}}</h1>1 X" m3 h( l9 d2 q' ^) \# y  J8 U& Y6 F
  4.     <h1>{{details()}}</h1>& Z" g0 T/ _* [
  5. </div>& j9 j6 @, `3 t/ y
  6. <script type="text/javascript">2 c3 K+ o7 N7 n1 q9 P: r. |
  7.     var vm = new Vue({8 p! Y2 B2 f- i
  8.         el: '#vue_det',% ]9 e9 f0 {1 u6 S2 g
  9.         data: {
    & J/ n! G0 b! J
  10.             site: "菜鸟教程",
    ) Z+ [$ J3 n! O  N3 P$ v& H
  11.             url: "www.runoob.com",
    / r( T" r; N' k( J5 b
  12.             alexa: "10000"$ T5 h: M# S$ O) }0 r
  13.         },* H& o* T7 i3 r/ R* o9 ]
  14.         methods: {
    & I2 u( k. B) i" u+ T7 I( j# g
  15.             details: function() {* `( U! X2 B' R. h8 ^$ c
  16.                 return  this.site + " - 学的不仅是技术,更是梦想!";
    / K% P& Z0 a+ G) d* o- V
  17.             }
    % z+ R& G  N% E7 W
  18.         }& D, N3 M( s- M. A0 T8 ^
  19.     })+ d' e1 P8 _  _, B
  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">6 ]  Q1 S% y. Z0 F& A% O/ |
  2.     <h1>site : {{site}}</h1># i) k/ Y& F: n$ c1 d8 D
  3.     <h1>url : {{url}}</h1>
    * f9 c. A9 }# o
  4.     <h1>{{details()}}</h1>/ g2 o: ^& n9 j! b
  5. </div>
复制代码
当一个 Vue 实例被创建时,它向 Vue 的响应式系统中加入了其 data 对象中能找到的所有的属性。当这些属性的值发生改变时,html 视图将也会产生相应的变化。
  1. <div id="vue_det">
    " N; @/ X5 N  p, h# f( N2 U0 d: Z
  2.     <h1>site : {{site}}</h1>( ^& n4 T0 y0 n- G
  3.     <h1>url : {{url}}</h1>
    : t. V9 B- o+ X/ Q" n
  4.     <h1>Alexa : {{alexa}}</h1>
    * Y6 ]9 U  P' O: u. V  n, D
  5. </div>
    ! l9 z; G/ K3 u7 O; a
  6. <script type="text/javascript">' ]7 w, K8 b; A. P
  7. // 我们的数据对象
    ! `1 a3 J* i* ^: q0 k
  8. var data = { site: "菜鸟教程", url: "www.runoob.com", alexa: 10000}
    / q0 x5 \" h* }: T5 G1 a; u! Z. Z' v
  9. var vm = new Vue({/ ]; A; j: u0 j4 O) L2 M+ |
  10.     el: '#vue_det',
    4 J* ]$ O- V2 ]( J  x6 |: |) {& w
  11.     data: data+ r# u* t* _: z0 b: X) I
  12. })* M4 z" v5 d- i# t8 S, M
  13. // 它们引用相同的对象!
    9 W/ x; z7 K% N
  14. document.write(vm.a === data.a) // true
    & X% J( B2 n8 |6 R6 \
  15. document.write("<br>")
    3 m# z5 |. u3 A  l
  16. // 设置属性也会影响到原始数据
    ! K; Y8 w. Y8 L& N( F  s! B1 N
  17. vm.site = "Runoob"# H& u; `( W4 o. X% z
  18. document.write(data.site + "<br>") // Runoob
    - B6 N: E( s& _5 O. D
  19. * D* _* D( a7 I  E$ t1 e
  20. // ……反之亦然8 u* B" d5 B3 ~$ j# N0 [
  21. data.alexa = 1234) s; j. D4 w3 _5 @& p3 b  X
  22. document.write(vm.alexa) // 1234
    7 U" S/ y* o4 A3 d  g6 v7 J$ u
  23. </script>
复制代码
除了数据属性,Vue 实例还提供了一些有用的实例属性与方法。它们都有前缀 $,以便与用户定义的属性区分开来。例如:
  1. <div id="vue_det">  l( s( G+ w1 u; N* @+ j+ j
  2.     <h1>site : {{site}}</h1>
    / B$ @# |6 b- W
  3.     <h1>url : {{url}}</h1>6 v$ Y* n+ y1 x- H) P5 B' E# n1 [* i
  4.     <h1>Alexa : {{alexa}}</h1>
    7 V  m) _7 u( G7 E7 E# I5 {
  5. </div>8 b8 u8 A4 L, y
  6. <script type="text/javascript">
    ! ^, ~1 P! h) B0 V5 {8 M( z
  7. // 我们的数据对象: D; h% {0 _! ~  `3 g( ~
  8. var data = { site: "菜鸟教程", url: "www.runoob.com", alexa: 10000}
    ' ~' F2 e. K6 r1 O& |8 @1 G
  9. var vm = new Vue({
    , r& A* i9 a$ M
  10.     el: '#vue_det',  ^' Z* G4 b: }
  11.     data: data" R, S1 L$ e8 \+ F( h* N% t
  12. })
    ) F: Z; T2 ?0 E3 K5 L0 Z3 C* s

  13.   r3 R0 W8 J$ i. l8 }
  14. document.write(vm.$data === data) // true1 M1 w6 ^8 m7 m& |2 y
  15. document.write("<br>") // true
    ! r2 Q4 f2 X5 {0 w
  16. document.write(vm.$el === document.getElementById('vue_det')) // true  U9 H, s8 Q) O9 o7 R4 ^$ K
  17. </script>
复制代码
( N# H7 Z2 r/ g& q6 f
! {7 O( y4 X0 E% r& m+ x5 m
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享分享 支持支持 反对反对
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

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