|
Vue.js 起步 每个 Vue 应用都需要通过实例化 Vue 来实现。 语法格式如下: - var vm = new Vue({
, ?, H3 }3 y! [/ |) l% p - // 选项5 Z8 z& r- @( O/ ]6 [
- })
复制代码接下来让我们通过实例来看下 Vue 构造器中需要哪些内容: - <div id="vue_det">% h+ w) V+ N. N0 K
- <h1>site : {{site}}</h1>
$ U& L/ f( b/ B, l - <h1>url : {{url}}</h1>
$ G# o! `9 v- _ - <h1>{{details()}}</h1>
$ Y# q$ ?0 L& w3 x, w7 H7 t" L - </div>( k/ U" r4 v9 n6 B
- <script type="text/javascript">. {( R) J. t9 D
- var vm = new Vue({7 I8 b5 Z8 ~5 z* f B
- el: '#vue_det',
8 E- S# |3 ?# C3 }3 b9 o - data: {
! R* @0 {; |7 `3 R& D - site: "菜鸟教程",
$ o" j/ u: x% B# A' g k: s$ c - url: "www.runoob.com",+ G/ \7 m& r9 W$ z
- alexa: "10000", |1 { q- v* j5 b
- },+ Q- }; `* h& K8 s ^! {
- methods: {
; e3 _$ S2 o) e; l- ` - details: function() {$ I2 [8 f1 R, H9 h
- return this.site + " - 学的不仅是技术,更是梦想!";
' T5 ?6 T- ^1 W: z' r. P4 C - }3 J4 R4 {4 e# u
- }5 E7 V) j' a% F) J, S; \, Z
- })
, [& U/ _) `% M8 u: N. K2 U0 o& b A - </script>
复制代码可以看到在 Vue 构造器中有一个el 参数,它是 DOM 元素中的 id。在上面实例中 id 为 vue_det,在 div 元素中: - <div id = "vue_det"></div>
复制代码这意味着我们接下来的改动全部在以上指定的 div 内,div 外部不受影响。 接下来我们看看如何定义数据对象。 data 用于定义属性,实例中有三个属性分别为:site、url、alexa。 methods 用于定义的函数,可以通过 return 来返回函数值。 {{ }} 用于输出对象属性和函数返回值。 - <div id="vue_det">& V6 `& ?" N" X; N
- <h1>site : {{site}}</h1>* E7 ^8 m C' s3 `- `/ e
- <h1>url : {{url}}</h1>/ I/ |, q; u2 O$ x! a5 J( D
- <h1>{{details()}}</h1>" f; Q/ ] D0 J8 k$ P
- </div>
复制代码当一个 Vue 实例被创建时,它向 Vue 的响应式系统中加入了其 data 对象中能找到的所有的属性。当这些属性的值发生改变时,html 视图将也会产生相应的变化。 - <div id="vue_det">* K! R# T, h( ]4 n0 x+ i4 _3 M3 W
- <h1>site : {{site}}</h1># Y# R7 O+ \% Q9 J: h6 }% y
- <h1>url : {{url}}</h1>
+ I: V$ T4 `0 h - <h1>Alexa : {{alexa}}</h1>: K% H0 r* g. V- |" o. P
- </div>6 P% [# v" i: _% G
- <script type="text/javascript">+ Q$ Q) _- m2 T# u7 l& i
- // 我们的数据对象- U9 w) P# H- u1 `$ }% C1 P
- var data = { site: "菜鸟教程", url: "www.runoob.com", alexa: 10000}( u% D. v% M5 O# ? L
- var vm = new Vue({
! K* d! K6 @- E( k* V - el: '#vue_det',0 |3 L* {1 z6 e) X
- data: data! W! R! {# ?* b- V
- })
+ @( Q* R' q% j8 L! h2 u - // 它们引用相同的对象!6 s; s' u$ M; t% F
- document.write(vm.a === data.a) // true
& P! u) T, H" i$ F3 ^( m - document.write("<br>"), |+ g' X" i" Y/ ?( M7 {
- // 设置属性也会影响到原始数据) E C9 ]$ r3 v
- vm.site = "Runoob", w# c5 U5 I8 _0 A& n
- document.write(data.site + "<br>") // Runoob
" c, r: W/ b m' @5 N+ R1 _' D - 8 m3 U) G1 Q6 k3 K7 W
- // ……反之亦然! Y) D. {2 ]% P9 |
- data.alexa = 1234
/ p# p7 j+ }# m) Y4 O' ` - document.write(vm.alexa) // 1234* U$ F5 m6 w" l" B4 P; {( Y- X' d
- </script>
复制代码除了数据属性,Vue 实例还提供了一些有用的实例属性与方法。它们都有前缀 $,以便与用户定义的属性区分开来。例如: - <div id="vue_det">
; A: {; c6 D* |4 X: e - <h1>site : {{site}}</h1>; t9 r* y. I. t8 q5 E
- <h1>url : {{url}}</h1>
; H2 {5 S3 O# d) Y. }5 j) \ - <h1>Alexa : {{alexa}}</h1>
9 k F) F- B0 T% c7 F, c+ q - </div>
; v" B, U7 F) z6 `! n - <script type="text/javascript">5 Q( C: ], E- F4 H
- // 我们的数据对象
9 h: e2 z9 G# n, L1 E; F/ D* Y% i3 r - var data = { site: "菜鸟教程", url: "www.runoob.com", alexa: 10000}. I3 h8 Y& s1 A6 P; c
- var vm = new Vue({" @, A1 g" T% W# m% z8 V" E
- el: '#vue_det',' P- |6 U0 Y0 o1 c6 ?
- data: data9 W1 z# m+ T* }/ s
- })
' o& ~& r7 n" J4 b) b( Y -
+ L' k, F! l% u. u9 J4 X& I - document.write(vm.$data === data) // true" e* D3 d% [ H' b% `
- document.write("<br>") // true0 z: e2 L6 m( K, g' N
- document.write(vm.$el === document.getElementById('vue_det')) // true) n/ a E$ G8 W3 |, [0 H
- </script>
复制代码
8 _* j" Q) H" T
; X. V8 g+ T/ J N: l* J; U |