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

QQ登录

只需一步,快速开始

 找回密码
 立即注册

QQ登录

只需一步,快速开始

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

[Vue.js] Vue.js 起步

[复制链接]
跳转到指定楼层
楼主
发表于 2018-7-1 23:08:58 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
Vue.js 起步
每个 Vue 应用都需要通过实例化 Vue 来实现。
语法格式如下:
  1. var vm = new Vue({, U3 X3 R! B  c3 B8 q6 W) f' `
  2.   // 选项
    3 ]' }& L; C/ j# r% S. ?
  3. })
复制代码
接下来让我们通过实例来看下 Vue 构造器中需要哪些内容:
  1. <div id="vue_det">
    $ k! x- Z' I2 t: O: S
  2.     <h1>site : {{site}}</h1>/ _/ ?( R' V5 R$ p- v3 V% q: }3 V
  3.     <h1>url : {{url}}</h1>  c+ V+ {+ T5 K- `: p
  4.     <h1>{{details()}}</h1>8 d0 ]$ E: V  S7 b! c8 T1 j) p( z
  5. </div>
    7 A! z/ h* ]+ W7 f& x
  6. <script type="text/javascript">
    # s8 ]% o7 _- O; }) f! f
  7.     var vm = new Vue({. ?5 C0 [8 S% B$ S% T3 N! F
  8.         el: '#vue_det',5 |8 X3 e/ o: Z/ k6 n; U- X! F2 m
  9.         data: {' B% T& ^  r* u# }0 H  m
  10.             site: "菜鸟教程",
    : y) i' j0 o" a3 c( i
  11.             url: "www.runoob.com",) I* U$ R$ G5 c; N
  12.             alexa: "10000"4 m% q' a) U. u, A( [
  13.         },
    ; Q2 Q. p1 o% K4 Y3 U3 o7 }
  14.         methods: {
    1 z! G' m# R: q0 X# |% \3 e
  15.             details: function() {
    ! k; C- Q3 ~9 r! ?( T2 S9 e4 v
  16.                 return  this.site + " - 学的不仅是技术,更是梦想!";* S( L6 t+ a6 F0 ^& ?1 f9 q
  17.             }) N! l8 \% j9 H4 _2 A& y# t
  18.         }
    * p% V3 a' |8 N$ d9 ^9 f1 H+ D" B$ x+ |
  19.     })
    ' l  y% c! n$ C2 G1 E* k# 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">4 S' ~0 [0 m; S+ n2 [( ~' Y
  2.     <h1>site : {{site}}</h1>; c; Q4 C8 ]6 d4 }  w( n
  3.     <h1>url : {{url}}</h1>
    . `) ?8 f( f& g7 @; d
  4.     <h1>{{details()}}</h1>. N  b5 ^) j" D6 b
  5. </div>
复制代码
当一个 Vue 实例被创建时,它向 Vue 的响应式系统中加入了其 data 对象中能找到的所有的属性。当这些属性的值发生改变时,html 视图将也会产生相应的变化。
  1. <div id="vue_det">& W2 X. t' @9 i( l( a( J3 ?" p% n
  2.     <h1>site : {{site}}</h1>! b- m. c; ~- w$ r
  3.     <h1>url : {{url}}</h1>
    / Z! Y# N% V7 \' h% b
  4.     <h1>Alexa : {{alexa}}</h1>
    4 z3 e/ k# w8 |" ?1 i- X: g
  5. </div>/ i* w3 Y1 p! \& c2 H" ]: c
  6. <script type="text/javascript">
    3 a9 N' k  M8 ^7 m! ^
  7. // 我们的数据对象& U! ^8 ?+ g7 ^, a3 A4 Z
  8. var data = { site: "菜鸟教程", url: "www.runoob.com", alexa: 10000}; `5 H) d' G; j2 ]: R1 k# W) \
  9. var vm = new Vue({- ^' L! \; A  [" B5 v$ [
  10.     el: '#vue_det',$ m. T0 M2 r" {; }
  11.     data: data
    / C: N, t" p$ \7 m8 Q# Z
  12. })$ B9 `$ Z8 u: F( M
  13. // 它们引用相同的对象!
    , G5 O2 r& s- M, K& `
  14. document.write(vm.a === data.a) // true
    # Y1 x5 k: W1 B) ~
  15. document.write("<br>")
    # N  M% U, A8 [$ `8 R8 x1 P2 m
  16. // 设置属性也会影响到原始数据9 ]- j2 f) c8 \0 X4 N' f- f$ ]
  17. vm.site = "Runoob"
    6 p/ w& |& U2 v: B
  18. document.write(data.site + "<br>") // Runoob
    + C  p% y& @; i* t
  19. " c8 q( F' L, e& B" L
  20. // ……反之亦然
    1 e7 |7 {6 F# d/ X0 O
  21. data.alexa = 12346 S4 _7 Q6 V' V% B8 n
  22. document.write(vm.alexa) // 1234! K' k4 j0 w6 r! @' I- j
  23. </script>
复制代码
除了数据属性,Vue 实例还提供了一些有用的实例属性与方法。它们都有前缀 $,以便与用户定义的属性区分开来。例如:
  1. <div id="vue_det">9 a( ~0 K! o7 g7 n
  2.     <h1>site : {{site}}</h1>" l' B! U6 U5 _7 \
  3.     <h1>url : {{url}}</h1>
    8 h/ {+ T/ k" G" `4 a8 r) T3 P
  4.     <h1>Alexa : {{alexa}}</h1>
    - e$ Q$ |0 f% Z; V6 K  h8 @9 F
  5. </div>
    5 W+ z/ g- _, j+ Y
  6. <script type="text/javascript">
    % F: {! k/ \" k
  7. // 我们的数据对象
    $ Z. [  z' ]- `3 |1 [  O* O9 `5 F! R4 x
  8. var data = { site: "菜鸟教程", url: "www.runoob.com", alexa: 10000}
    ) \, i3 T; F4 B
  9. var vm = new Vue({8 i8 X( R( V+ y& V& k3 {! L
  10.     el: '#vue_det',
    8 K# H$ C* m  c% V' ~. I& g/ [
  11.     data: data2 x4 P& E6 T4 o3 h; Z
  12. })
    . D! ?# O6 i) u2 i3 K6 j; `: F6 c/ C

  13. 7 }& n/ ~4 c9 i5 s& S
  14. document.write(vm.$data === data) // true  K# l) K8 P& J2 r9 x$ ~, `3 o+ a
  15. document.write("<br>") // true9 F1 u% K0 V$ r$ x
  16. document.write(vm.$el === document.getElementById('vue_det')) // true$ n. c4 I, W$ T! c
  17. </script>
复制代码

! z0 O, Q$ E4 `4 h! D  d) t$ R3 O9 n! I# O! o3 m/ U4 c) h% s' x
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享分享 支持支持 反对反对
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

GMT+8, 2026-5-2 13:34 , Processed in 0.051868 second(s), 19 queries .

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