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

QQ登录

只需一步,快速开始

 找回密码
 立即注册

QQ登录

只需一步,快速开始

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

[Vue.js] Vue.js 起步

[复制链接]
跳转到指定楼层
楼主
发表于 2018-7-1 23:08:58 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
Vue.js 起步
每个 Vue 应用都需要通过实例化 Vue 来实现。
语法格式如下:
  1. var vm = new Vue({( Q) h' q7 }; T& p9 V/ E, T$ I
  2.   // 选项
    + |0 V, V3 O5 z
  3. })
复制代码
接下来让我们通过实例来看下 Vue 构造器中需要哪些内容:
  1. <div id="vue_det">5 M9 ~1 q# w# `$ ~9 S2 L6 q
  2.     <h1>site : {{site}}</h1>
    * P, l! I/ n/ o* j* E$ o
  3.     <h1>url : {{url}}</h1>: A  W# W2 S/ r" M/ ]
  4.     <h1>{{details()}}</h1>
    4 O9 ?" n, {5 `* P
  5. </div>5 E- G$ \: O& g9 v, Y1 d9 u8 Y
  6. <script type="text/javascript">+ y! p; |1 K5 o7 y* U, l' `1 ]
  7.     var vm = new Vue({
    6 C/ F; x5 V/ r
  8.         el: '#vue_det',
    3 k: P; i* G+ l3 |# m  R
  9.         data: {% ]0 \8 |9 w, r+ I
  10.             site: "菜鸟教程",8 a1 b# V( p0 D, E) k: I4 ]
  11.             url: "www.runoob.com",
    : |- L2 r8 E0 u5 m8 Q$ w4 U
  12.             alexa: "10000"
    " e( q% F" N3 G
  13.         },* b, h6 N, u# Y
  14.         methods: {
    ! \$ R# t8 y) I' D. x! M& k
  15.             details: function() {
    & g! ?+ ?  P8 \/ ^( N) U( b
  16.                 return  this.site + " - 学的不仅是技术,更是梦想!";
    $ C  z, ~7 Z/ x# q. F
  17.             }
    ! f1 n; b9 q- r$ C
  18.         }4 x7 L6 k- {" [7 y" E  I
  19.     })$ c$ w8 n5 G9 Z$ i+ l( _
  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">! t0 P- ?' r- ?4 w7 g9 N
  2.     <h1>site : {{site}}</h1>
    ) ^) @& L% o+ N3 n# p- L
  3.     <h1>url : {{url}}</h1>
    ) ^" w2 D. r* V7 {
  4.     <h1>{{details()}}</h1>
    6 I& U: x$ U7 D7 a; q
  5. </div>
复制代码
当一个 Vue 实例被创建时,它向 Vue 的响应式系统中加入了其 data 对象中能找到的所有的属性。当这些属性的值发生改变时,html 视图将也会产生相应的变化。
  1. <div id="vue_det">! P( @; ^0 t& k
  2.     <h1>site : {{site}}</h1>3 g% J& z1 X1 Z
  3.     <h1>url : {{url}}</h1>
    . e; M* s& o* H! E
  4.     <h1>Alexa : {{alexa}}</h1>
    ! E* i- |6 j! [6 T* N5 k
  5. </div>
    . p% S0 C: C( w  W! j
  6. <script type="text/javascript">5 s# P# G6 F; }! @) X  e
  7. // 我们的数据对象7 |5 y# l" j4 S1 x$ }' g8 n
  8. var data = { site: "菜鸟教程", url: "www.runoob.com", alexa: 10000}
    6 O9 P/ x/ @  ~7 N
  9. var vm = new Vue({+ [! g0 n) X1 H7 }( {! o/ j' D
  10.     el: '#vue_det',5 {3 r3 P( A- e% `2 ~" u
  11.     data: data
    8 c. g4 p/ `) r8 m
  12. })
    5 ^( s8 V- m9 G* ]) Y
  13. // 它们引用相同的对象!0 H0 Y/ E! g) ~; V1 a' I) ~- l
  14. document.write(vm.a === data.a) // true
    ) b- U: \/ G& G7 C: K7 ?; [9 J# S
  15. document.write("<br>")
    3 ~* r) n$ a& B0 N
  16. // 设置属性也会影响到原始数据# Y) M' ?8 R+ }0 f
  17. vm.site = "Runoob"5 T* F5 t& \8 m. k
  18. document.write(data.site + "<br>") // Runoob
    ! W$ V: [5 i3 o$ ^  ]% n/ _

  19. , l! T& A! B: D  m( V
  20. // ……反之亦然9 |' D7 Z" V9 R+ w. R, ?& i$ P
  21. data.alexa = 1234  S2 ^1 k0 U0 q4 }. f/ l* B1 ?' |
  22. document.write(vm.alexa) // 12340 r+ C9 v# m' ^8 b, |
  23. </script>
复制代码
除了数据属性,Vue 实例还提供了一些有用的实例属性与方法。它们都有前缀 $,以便与用户定义的属性区分开来。例如:
  1. <div id="vue_det">
    ( ~# M0 I  ]5 D, W" l) e2 `
  2.     <h1>site : {{site}}</h1>
    - M( P/ g6 @3 G
  3.     <h1>url : {{url}}</h1>& G# i7 t5 |; ?4 z4 F, u3 e( z
  4.     <h1>Alexa : {{alexa}}</h1>
    , n. V' `/ q$ p$ n% P1 e" T1 W
  5. </div>
    : N2 {; h  Q- V7 b& ?' x' o
  6. <script type="text/javascript">
      g# S; Q" F, I! {
  7. // 我们的数据对象
    * Z2 h' N: U# S! F! I7 _
  8. var data = { site: "菜鸟教程", url: "www.runoob.com", alexa: 10000}
    $ y5 P+ I/ R4 T2 z8 R
  9. var vm = new Vue({
    0 x( x9 F1 I0 J# m+ S; z, [0 p' k
  10.     el: '#vue_det',
    ( V/ y! v/ p3 |! y% U6 q2 _
  11.     data: data3 t! y9 ?  i) `! V, b1 b
  12. })
    & q* d* L- M8 ~' q# V- Q$ M

  13. - U1 j1 w6 L# m/ [
  14. document.write(vm.$data === data) // true
    . ~+ C% S0 T# E
  15. document.write("<br>") // true3 a8 T. P# j/ Y! U+ ?) k
  16. document.write(vm.$el === document.getElementById('vue_det')) // true
    * m9 ~6 o1 h2 D7 Z! }+ Z# l% J
  17. </script>
复制代码
8 u$ M( _' L+ A/ A0 O: R. B

' W5 Q) D  b1 @1 V, o
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享分享 支持支持 反对反对
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

GMT+8, 2026-6-19 22:40 , Processed in 0.062461 second(s), 19 queries .

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