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

QQ登录

只需一步,快速开始

 找回密码
 立即注册

QQ登录

只需一步,快速开始

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

[Vue.js] Vue.js 起步

[复制链接]
跳转到指定楼层
楼主
发表于 2018-7-1 23:08:58 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
Vue.js 起步
每个 Vue 应用都需要通过实例化 Vue 来实现。
语法格式如下:
  1. var vm = new Vue({
    . Q- e. D& |5 D$ l+ Z1 e: d4 Q1 Z4 `
  2.   // 选项
    5 a8 A- A1 S+ e. o; g8 i
  3. })
复制代码
接下来让我们通过实例来看下 Vue 构造器中需要哪些内容:
  1. <div id="vue_det">8 t: H. A7 O7 t7 c
  2.     <h1>site : {{site}}</h1>- D* L4 c, K+ E9 J6 j0 m+ g
  3.     <h1>url : {{url}}</h1>2 c1 E, I3 d' j( D. @- o
  4.     <h1>{{details()}}</h1>
    : k5 n4 a" ?4 d; H- o( M
  5. </div>
    - e! K4 ]/ D& \. ^- B: r
  6. <script type="text/javascript">  L  A9 }' x, i% ~" j
  7.     var vm = new Vue({
    0 i% ~$ s6 \  B1 ]5 O+ o
  8.         el: '#vue_det',
    3 H& [+ d, [$ C& X0 L6 X+ S4 a
  9.         data: {, K' U( O  [0 a3 P6 `: j5 P# a/ ^
  10.             site: "菜鸟教程",; w' r+ H2 |, m! {0 _9 J* D
  11.             url: "www.runoob.com",
    , J, N) s: h0 Q5 j
  12.             alexa: "10000"
    4 ?# p/ L; G. I% i, x2 G$ K
  13.         },8 Y9 k  K# C8 B7 T8 j) h
  14.         methods: {
    * e7 _. c- [4 u# g* ?( `4 M
  15.             details: function() {
    " ~  M1 p) _' g
  16.                 return  this.site + " - 学的不仅是技术,更是梦想!";7 B. z1 l) t1 T# A8 s
  17.             }
    & x: ~' y8 q/ w$ L( k
  18.         }
    % j1 G; f. I* i  Y/ ^9 G* O
  19.     })
    : L/ s2 o+ i9 d. d& F/ f6 x
  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">$ l6 i6 M7 \4 w5 R+ k
  2.     <h1>site : {{site}}</h1>! s+ \: }; K" V! R4 v( L- H# N7 D6 B
  3.     <h1>url : {{url}}</h1>
    9 Q$ d7 L( Z  e" Y
  4.     <h1>{{details()}}</h1>
    - {) d! z5 a& z2 J9 N3 j" i9 J5 [
  5. </div>
复制代码
当一个 Vue 实例被创建时,它向 Vue 的响应式系统中加入了其 data 对象中能找到的所有的属性。当这些属性的值发生改变时,html 视图将也会产生相应的变化。
  1. <div id="vue_det">
    9 r# l5 ?1 @8 t
  2.     <h1>site : {{site}}</h1>
    $ [+ _6 m5 k5 j" y
  3.     <h1>url : {{url}}</h1>
      x! ~2 C$ g6 B* j: i. q4 M
  4.     <h1>Alexa : {{alexa}}</h1>1 J8 h+ U1 r7 R
  5. </div>
    6 A4 z5 q" l- X1 h
  6. <script type="text/javascript">
    8 s. C# U/ E- L. b, e+ x1 Z
  7. // 我们的数据对象# f* t* g+ {& P, R
  8. var data = { site: "菜鸟教程", url: "www.runoob.com", alexa: 10000}$ d* E* `1 L" d) k
  9. var vm = new Vue({
    % {$ r7 p8 O3 e% L' r
  10.     el: '#vue_det',4 H  h$ v4 W; |- x
  11.     data: data3 ]7 r+ ^1 i% s0 z) U& _! _
  12. })
    * @# g5 e7 C+ G( A) X2 L
  13. // 它们引用相同的对象!, O8 ~% \$ n3 ?7 P" P. A4 ?
  14. document.write(vm.a === data.a) // true* P3 V! v, h2 B" J: Q5 U
  15. document.write("<br>")
    # t& n8 g+ K6 ~
  16. // 设置属性也会影响到原始数据" C8 B2 v# E& l; m  A: L7 Y( b
  17. vm.site = "Runoob"
    # t9 j7 T) P3 Q( Y' U/ O
  18. document.write(data.site + "<br>") // Runoob
    0 g+ }+ ]1 o( Z$ b' g

  19. % i/ V8 W' G( n* R' _; i
  20. // ……反之亦然
    2 q* Q$ p9 c! v  N) ]! U5 U& e
  21. data.alexa = 1234/ L2 x, l. }4 b3 }! k
  22. document.write(vm.alexa) // 1234
    1 B) G3 O" O7 d2 {
  23. </script>
复制代码
除了数据属性,Vue 实例还提供了一些有用的实例属性与方法。它们都有前缀 $,以便与用户定义的属性区分开来。例如:
  1. <div id="vue_det">. u2 M7 Z0 c6 i, R* h. ~& v
  2.     <h1>site : {{site}}</h1>
      m2 A/ l$ r7 o% y- U: m
  3.     <h1>url : {{url}}</h1>
    , E* b" c3 w: }) p5 B& i& N
  4.     <h1>Alexa : {{alexa}}</h1>
    1 v3 `+ P7 D+ I# n; Z# I. U$ b  V
  5. </div>
    & o" m1 F: N# T' d4 a
  6. <script type="text/javascript">
    9 \1 T2 o, c) ^% I3 G
  7. // 我们的数据对象* ]3 O2 _8 a1 C- P7 K' [: r
  8. var data = { site: "菜鸟教程", url: "www.runoob.com", alexa: 10000}3 \" w: j* m" Y& Q0 t
  9. var vm = new Vue({
    6 C1 n. M  t7 d. m8 \  N$ }* R
  10.     el: '#vue_det',8 g* j; B) G+ K( |0 u0 ^0 P9 G
  11.     data: data
    # E3 X/ U0 f' m. J# }* ?
  12. })
    ; p( w6 t6 `4 z& Y" O1 B
  13. 3 T' y1 h) y3 ]* [8 J
  14. document.write(vm.$data === data) // true
    $ ?, a8 d6 G/ C
  15. document.write("<br>") // true
    % U8 j% k/ _2 b$ _4 b( X
  16. document.write(vm.$el === document.getElementById('vue_det')) // true) i/ v! A, M  R# U! I7 {9 N" h- N6 v
  17. </script>
复制代码

# A# p  Z2 t$ }4 e, c7 D/ c8 a/ Q
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享分享 支持支持 反对反对
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

GMT+8, 2026-1-30 11:40 , Processed in 0.078172 second(s), 20 queries .

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