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

QQ登录

只需一步,快速开始

 找回密码
 立即注册

QQ登录

只需一步,快速开始

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

[Vue.js] Vue.js 起步

[复制链接]
跳转到指定楼层
楼主
发表于 2018-7-1 23:08:58 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
Vue.js 起步
每个 Vue 应用都需要通过实例化 Vue 来实现。
语法格式如下:
  1. var vm = new Vue({
    & c! ]3 r0 |. _9 x* w/ n
  2.   // 选项7 M9 ^! F4 i0 r6 w! D% {
  3. })
复制代码
接下来让我们通过实例来看下 Vue 构造器中需要哪些内容:
  1. <div id="vue_det">
    " P9 v; `: C, q
  2.     <h1>site : {{site}}</h1>2 ~% ~3 h5 |4 K
  3.     <h1>url : {{url}}</h1>, P5 ~. X( s0 Z6 [5 Y/ w* R4 K0 Q
  4.     <h1>{{details()}}</h1>1 C/ U% A' L" R" q
  5. </div>
    0 X0 _& R/ `9 I2 D7 m
  6. <script type="text/javascript">
    8 o# ~' t" J& a9 s% v0 w$ R
  7.     var vm = new Vue({
    - E1 u% |8 B/ c3 L+ q8 W, H
  8.         el: '#vue_det',
    $ r5 D; P; ~4 ?( C2 P* B$ e+ O
  9.         data: {8 X5 A! r" Z: q* w
  10.             site: "菜鸟教程",, l  O% m- v0 {, W
  11.             url: "www.runoob.com",
    6 i2 D3 w3 f( ?! z  q3 b# w
  12.             alexa: "10000"/ K* A6 V# |" V' E! }+ ]+ U
  13.         },2 O' D+ v* b3 A$ o+ e
  14.         methods: {2 F  e7 |6 O: q( n
  15.             details: function() {* V/ c" _, X5 _4 w
  16.                 return  this.site + " - 学的不仅是技术,更是梦想!";( m5 V. ^  K" m* J. j. i
  17.             }# P, z$ B- f0 r- K  W2 g
  18.         }
    $ h3 H# o, S( h
  19.     })
    1 j% t% O5 V& Q6 m- e
  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 @' r4 o7 j+ v* p: T! o; Z) L$ x
  2.     <h1>site : {{site}}</h1>
    4 ~2 j8 t3 u: p$ V6 U* o
  3.     <h1>url : {{url}}</h1>
    2 j& v7 J; }6 M) J- n+ |8 g
  4.     <h1>{{details()}}</h1>( y' Z0 T* q. h9 H7 V
  5. </div>
复制代码
当一个 Vue 实例被创建时,它向 Vue 的响应式系统中加入了其 data 对象中能找到的所有的属性。当这些属性的值发生改变时,html 视图将也会产生相应的变化。
  1. <div id="vue_det">
    5 j- \6 T, w! V) G8 F+ S8 |$ d
  2.     <h1>site : {{site}}</h1>
    / @! e# ~0 B8 t) z  V4 B  Q
  3.     <h1>url : {{url}}</h1>
    * S+ _& B0 `! C2 B7 l& F( b
  4.     <h1>Alexa : {{alexa}}</h1>
    ( W7 T% i, g7 f2 I2 h  h/ K
  5. </div>
    $ p2 @' L. P* _* Q
  6. <script type="text/javascript">
    * _5 a- U3 `' W3 D  t
  7. // 我们的数据对象
    1 K  k/ W* E3 c5 S
  8. var data = { site: "菜鸟教程", url: "www.runoob.com", alexa: 10000}
    % ^7 T4 Z2 ?( O; n8 R* d
  9. var vm = new Vue({# m8 X0 ^) K$ V  j' Q
  10.     el: '#vue_det',
    / ?) W' K  g& i7 z- T; i  o# q
  11.     data: data
    1 l7 w" y- R5 o
  12. })
    1 g  _# J$ v/ y" [5 Q7 O+ ^
  13. // 它们引用相同的对象!
    * h5 u" T0 ]9 o: b
  14. document.write(vm.a === data.a) // true' d1 n- h. J9 n" A4 k
  15. document.write("<br>")
    2 ]6 a  I; r! F: F: n; k- w, G
  16. // 设置属性也会影响到原始数据
    % Y; H* w- v4 {4 U
  17. vm.site = "Runoob"
    4 V  {; o! e+ ?3 u
  18. document.write(data.site + "<br>") // Runoob
    6 u$ z" N9 Z( P2 S

  19. 7 i, F0 W/ _) |0 E! l
  20. // ……反之亦然
    5 _# I6 u3 s4 T0 ?
  21. data.alexa = 1234, i5 u3 I3 h9 @8 S* o
  22. document.write(vm.alexa) // 1234
    2 g4 C- A( O, o4 s
  23. </script>
复制代码
除了数据属性,Vue 实例还提供了一些有用的实例属性与方法。它们都有前缀 $,以便与用户定义的属性区分开来。例如:
  1. <div id="vue_det">
    9 B7 P3 M% K, J8 V
  2.     <h1>site : {{site}}</h1>
    . T6 y& ~$ r) B: J, L" z5 K
  3.     <h1>url : {{url}}</h1>* P5 m4 `4 v: i
  4.     <h1>Alexa : {{alexa}}</h1>  x& |& [, H( U
  5. </div>
    9 A3 u+ N: R) \& n, k- C0 e' ]. {
  6. <script type="text/javascript">
    : a+ l& F" ?( N2 C% r& G8 u
  7. // 我们的数据对象
    - R" ?4 P  M- z. |( f  R+ z
  8. var data = { site: "菜鸟教程", url: "www.runoob.com", alexa: 10000}/ D% q8 k) l  J! o
  9. var vm = new Vue({1 n# x) q/ {9 n6 E4 _2 t0 e; `
  10.     el: '#vue_det',
    . U8 Y: E% J9 N' ]- k+ \
  11.     data: data6 l: E3 m4 i/ G/ P9 O. p
  12. })
    , \3 }" ^! M  X
  13. ! q7 {' ]. ~; D1 \. Y
  14. document.write(vm.$data === data) // true" U# C) P5 ?" m. f
  15. document.write("<br>") // true
    & ]! s2 i4 V4 z. }1 O8 B( v
  16. document.write(vm.$el === document.getElementById('vue_det')) // true
    9 b8 @. n# B5 `- c9 C! \2 k) v
  17. </script>
复制代码

# s* J& G- i* a+ R) c
- n% T1 b, Q& Y- H
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享分享 支持支持 反对反对
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

GMT+8, 2024-5-18 13:59 , Processed in 0.110973 second(s), 19 queries .

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