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

QQ登录

只需一步,快速开始

 找回密码
 立即注册

QQ登录

只需一步,快速开始

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

[Vue.js] Vue.js 起步

[复制链接]
跳转到指定楼层
楼主
发表于 2018-7-1 23:08:58 | 只看该作者 回帖奖励 |正序浏览 |阅读模式
Vue.js 起步
每个 Vue 应用都需要通过实例化 Vue 来实现。
语法格式如下:
  1. var vm = new Vue({
    7 f/ z; |9 N0 `* {3 f# \- ^
  2.   // 选项% |4 u( ~2 k6 Z
  3. })
复制代码
接下来让我们通过实例来看下 Vue 构造器中需要哪些内容:
  1. <div id="vue_det">
    9 U: [" V, j9 ^# i
  2.     <h1>site : {{site}}</h1>
    . ^9 e4 w2 C- `7 M; l7 U
  3.     <h1>url : {{url}}</h1># C8 ^( v5 ~  @+ e. \+ [  b+ G# p
  4.     <h1>{{details()}}</h1>1 B7 D0 l' C1 l1 B9 q- a# P  N1 @
  5. </div>
    , Q! ?/ E4 f0 F5 j
  6. <script type="text/javascript">1 b5 ~: G7 h' m- a2 v3 p9 g
  7.     var vm = new Vue({% z2 u+ y& P6 ^( y2 T+ u! @1 j* X
  8.         el: '#vue_det',* Y4 J  F) P) ~+ X0 U0 C
  9.         data: {
    % D6 o; z. C9 v( h) X
  10.             site: "菜鸟教程",, ^, }& H9 y) O5 O' o6 }; Q0 Z" `
  11.             url: "www.runoob.com",
    ; X% C$ W8 ~& y
  12.             alexa: "10000"* N0 D* `% u/ c7 x
  13.         },& q4 v7 K  M5 Z, u( b/ e+ X+ C
  14.         methods: {
    # i0 P+ |6 o8 |
  15.             details: function() {6 \' k  o& b5 L6 k/ P: y" X
  16.                 return  this.site + " - 学的不仅是技术,更是梦想!";
    1 B: {% U" S7 Q2 f" m" u9 ?
  17.             }+ V2 p+ E! R; q, x+ i
  18.         }
    9 D8 N3 i) u3 n2 y- S' C% m
  19.     })
    8 M7 k5 v: |6 X- k+ \, \
  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">
    4 r8 o: B2 k  @: H! Y
  2.     <h1>site : {{site}}</h1>
    % b5 Z5 E* e! A* y. f
  3.     <h1>url : {{url}}</h1>
    5 n8 a5 p0 h7 d' y' Y
  4.     <h1>{{details()}}</h1>
    8 z2 H. t% s1 ?9 n/ h
  5. </div>
复制代码
当一个 Vue 实例被创建时,它向 Vue 的响应式系统中加入了其 data 对象中能找到的所有的属性。当这些属性的值发生改变时,html 视图将也会产生相应的变化。
  1. <div id="vue_det">8 ?) z1 t: B2 ]# j" _! T
  2.     <h1>site : {{site}}</h1>
    - Q& Y( Y: s! b
  3.     <h1>url : {{url}}</h1>6 P6 F8 l6 N$ D5 T3 o$ \  f
  4.     <h1>Alexa : {{alexa}}</h1>' O& L; w5 G7 ?: ]* A# P4 E0 Y
  5. </div>* \" r5 I4 S8 ^0 O& [2 M
  6. <script type="text/javascript">
    4 J/ F% |5 d6 P0 }# k$ @# M8 P
  7. // 我们的数据对象
    9 N9 G1 y) P. a" @- a: m# }; S! V
  8. var data = { site: "菜鸟教程", url: "www.runoob.com", alexa: 10000}
      q; X# K3 U! o- o8 L- l" B2 H$ f
  9. var vm = new Vue({' g% X/ C, i3 U& z2 U! V& D( t
  10.     el: '#vue_det',
    * A! N1 C1 @/ y) L# l% v
  11.     data: data
    1 E  {& ?$ K* p" z/ e/ i/ s
  12. })0 i6 a+ Y7 F& ?  T9 U& Z7 U
  13. // 它们引用相同的对象!, N' y+ g4 R" i) N% O
  14. document.write(vm.a === data.a) // true8 f6 L% K8 D+ a4 l  x$ Y  t. I
  15. document.write("<br>"); E6 C/ G+ \+ ^9 n7 s4 c
  16. // 设置属性也会影响到原始数据
    ) F0 S8 `* A6 v3 Z
  17. vm.site = "Runoob"
    / S, |5 f. M. i
  18. document.write(data.site + "<br>") // Runoob
    $ Z7 |: Y3 Q* z

  19. 5 ~2 y' k2 z, L# n$ z. X
  20. // ……反之亦然$ N% r4 w3 r$ P# z( {( n: W$ N
  21. data.alexa = 1234/ V; P2 _. S+ i. o/ _( P2 U( [, o
  22. document.write(vm.alexa) // 1234  Y% u. b& w9 u, j1 }. H8 z
  23. </script>
复制代码
除了数据属性,Vue 实例还提供了一些有用的实例属性与方法。它们都有前缀 $,以便与用户定义的属性区分开来。例如:
  1. <div id="vue_det">* h7 v. p% X/ ?
  2.     <h1>site : {{site}}</h1>( C" ^9 q0 t" \3 o* X5 w
  3.     <h1>url : {{url}}</h1>/ q3 S1 T" I6 C3 Y$ G
  4.     <h1>Alexa : {{alexa}}</h1>% E/ a) |  N$ t% C6 N5 }5 j$ @/ p1 V
  5. </div>) Q% |0 w- E1 I  T! x2 j4 R
  6. <script type="text/javascript">1 t! d: p/ m1 I! a9 f9 F, P; V
  7. // 我们的数据对象
    7 b1 {  Z# ~( |$ X9 V, p
  8. var data = { site: "菜鸟教程", url: "www.runoob.com", alexa: 10000}( |5 C6 y$ R) `. d0 v" ?! M
  9. var vm = new Vue({8 J- c. M/ h4 b7 t( p2 I6 V
  10.     el: '#vue_det',
    / |$ K* E% Y- r+ h  ~4 t# K' A
  11.     data: data) E4 V0 ^0 K" F2 F! ^
  12. })% H3 \- J. d) N1 y6 K) d7 w8 e4 x) d2 A1 W5 P

  13. 8 q7 c" o+ ^5 S9 f
  14. document.write(vm.$data === data) // true' Y1 B+ y' B2 T* [( T, w
  15. document.write("<br>") // true
    3 K1 ], ?, L. l  M6 Z, ?- ?, O
  16. document.write(vm.$el === document.getElementById('vue_det')) // true2 \( G6 I' X: c" ~1 ]( D
  17. </script>
复制代码

+ m1 [2 x5 y" \3 s$ M
! b6 Q3 t2 b9 Z7 W2 b1 R+ I1 j0 e2 l
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享分享 支持支持 反对反对
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

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