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

QQ登录

只需一步,快速开始

 找回密码
 立即注册

QQ登录

只需一步,快速开始

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

[Vue.js] Vue.js 起步

[复制链接]
跳转到指定楼层
楼主
发表于 2018-7-1 23:08:58 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
Vue.js 起步
每个 Vue 应用都需要通过实例化 Vue 来实现。
语法格式如下:
  1. var vm = new Vue({
    0 R! f# h$ B+ }1 ~) o3 ~
  2.   // 选项
      A/ ?0 A, U1 D2 a
  3. })
复制代码
接下来让我们通过实例来看下 Vue 构造器中需要哪些内容:
  1. <div id="vue_det">
    0 E  F+ m! S% m
  2.     <h1>site : {{site}}</h1>
    0 H# L& T( a( a, o" R
  3.     <h1>url : {{url}}</h1>
    ) @1 j+ o; n" C, g0 _
  4.     <h1>{{details()}}</h1>) p( O& m$ g, @+ Z$ U: b( [
  5. </div>+ C* x  E* m" j$ m; M+ y0 C. w' K
  6. <script type="text/javascript">9 A. [# y2 F3 l2 h
  7.     var vm = new Vue({
    " t: n5 c9 L: B! c! G( X/ D. \
  8.         el: '#vue_det',
    1 \# W0 u; f9 A* E, {- _& C
  9.         data: {0 P: N. p& |/ X: X
  10.             site: "菜鸟教程",
    0 h( ^. Z% F5 z( L$ M: K
  11.             url: "www.runoob.com",) W: x# l! [  t- C: x
  12.             alexa: "10000"
    , D' o* i* u  F$ t6 ~; K4 |
  13.         },* @7 E3 t( m) {6 p% W2 p/ Y
  14.         methods: {- \% K7 }, Q6 i/ }( P$ @, r
  15.             details: function() {; |9 x+ k$ ]  A
  16.                 return  this.site + " - 学的不仅是技术,更是梦想!";! u. G( |6 a. ?5 o; O( h
  17.             }
    ! ~5 n: F- S3 E8 M6 W" Y
  18.         }$ o. H( U  R/ n) n( ~1 p
  19.     }); P" C1 i: _3 G  e: F
  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">
    * e: J3 e4 b( t
  2.     <h1>site : {{site}}</h1>8 y8 U0 Y' |% v1 b
  3.     <h1>url : {{url}}</h1>/ l; a7 D' ^. M
  4.     <h1>{{details()}}</h1>
    , C- ?) H; M% m# a. I' C
  5. </div>
复制代码
当一个 Vue 实例被创建时,它向 Vue 的响应式系统中加入了其 data 对象中能找到的所有的属性。当这些属性的值发生改变时,html 视图将也会产生相应的变化。
  1. <div id="vue_det">
    ; G) G. P+ P) g! O1 E
  2.     <h1>site : {{site}}</h1>
    2 k: u0 G  E5 R5 f" f  v0 Z
  3.     <h1>url : {{url}}</h1>" n- N) U: R. g: e1 p- R# V7 i
  4.     <h1>Alexa : {{alexa}}</h1>2 B0 t5 M  M( n( I! E+ i
  5. </div>9 d/ `9 P1 L& [1 G- v( ?( k: k* j
  6. <script type="text/javascript">2 q' y: N  ?3 ]! g, `8 `' H
  7. // 我们的数据对象& Q( I9 {4 d& _
  8. var data = { site: "菜鸟教程", url: "www.runoob.com", alexa: 10000}9 t: g# ~) n7 \- N: F1 G
  9. var vm = new Vue({
    5 ]5 S" {" c; \  X' V9 q
  10.     el: '#vue_det',
    : ]7 K: h! q6 j
  11.     data: data$ g# }; \  ^0 T" _! s5 ^
  12. }), A6 f4 x" U# x( N( x3 o$ n
  13. // 它们引用相同的对象!$ A4 d  U' X* M* f- ?
  14. document.write(vm.a === data.a) // true
    * Q, o% N# K- X
  15. document.write("<br>")
    ( Y* k8 Z1 y* ?5 b/ ]
  16. // 设置属性也会影响到原始数据
      J$ ^" S( H1 f2 V1 j
  17. vm.site = "Runoob"
    2 c& ~" C# W8 a9 k
  18. document.write(data.site + "<br>") // Runoob
    ( z2 i( S; I2 u
  19. * f. D2 z6 N( a3 B5 \7 ]3 J3 z, L5 F
  20. // ……反之亦然# a6 V- b5 C( ?5 l6 Y, Z" E. ]( B7 ^
  21. data.alexa = 1234% O- R8 \! ^$ C3 D- p+ l2 x! `
  22. document.write(vm.alexa) // 1234! D7 d+ x% v) F$ [) |& t' ?3 b# l% c
  23. </script>
复制代码
除了数据属性,Vue 实例还提供了一些有用的实例属性与方法。它们都有前缀 $,以便与用户定义的属性区分开来。例如:
  1. <div id="vue_det">
    2 I- g+ n: X% T/ K1 d4 ?
  2.     <h1>site : {{site}}</h1>% h3 j1 Q8 A. C3 t6 i; E8 d
  3.     <h1>url : {{url}}</h1>' @6 U, p$ ?+ \9 ]
  4.     <h1>Alexa : {{alexa}}</h1>% o+ }  r2 x( U( _2 u0 v$ `- U
  5. </div>
    0 ]/ h" O( }: p" D
  6. <script type="text/javascript">/ x7 P* q% P1 n+ ^& Z+ A6 [, \
  7. // 我们的数据对象! L+ g& s9 j/ I" G' t8 }/ }5 Z  t
  8. var data = { site: "菜鸟教程", url: "www.runoob.com", alexa: 10000}
    3 `! s  A8 ]; P
  9. var vm = new Vue({
    2 y& V' h/ W: X& W# V
  10.     el: '#vue_det',% J1 t1 }. N6 Q/ V4 h, ]
  11.     data: data
    ( B9 N2 y/ Z1 H- u
  12. })2 T9 v% `# G/ |3 r* `  d4 I/ z0 z
  13. 1 `3 Z" r+ ~4 B7 m: L' t
  14. document.write(vm.$data === data) // true7 I6 n/ p9 d8 o9 ?) j$ I
  15. document.write("<br>") // true: O3 C, l( A' b5 ]0 J, v/ [
  16. document.write(vm.$el === document.getElementById('vue_det')) // true1 {/ q2 @0 Y3 I2 B
  17. </script>
复制代码

( s; `$ M3 X) r" c3 U
; N7 B8 y4 }5 ~/ ~
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享分享 支持支持 反对反对
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

GMT+8, 2026-1-30 14:29 , Processed in 0.071066 second(s), 20 queries .

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