|
Vue.js 起步 每个 Vue 应用都需要通过实例化 Vue 来实现。 语法格式如下: - var vm = new Vue({
! A+ L& w, h, G+ i+ | - // 选项, q" j Q- S0 q y
- })
复制代码接下来让我们通过实例来看下 Vue 构造器中需要哪些内容: - <div id="vue_det">
4 _9 G: |; I% Q! ~1 \ - <h1>site : {{site}}</h1>
$ @& p& v4 v1 _* ~ - <h1>url : {{url}}</h1>
' i; |0 N# C# f9 T: ]! \ - <h1>{{details()}}</h1>1 p" E3 W* l& a8 Z" G+ i
- </div>
% A0 j1 E/ i- j3 {9 z. U - <script type="text/javascript">
$ c7 w {/ e+ s9 L Z0 N& D: | - var vm = new Vue({
# K0 ^8 n% J" F# ]9 G - el: '#vue_det',
3 G/ N5 i4 H) b - data: {
9 f$ y( s( P: x% g. O" w - site: "菜鸟教程",
1 Z8 [( E( ?. C$ [" j4 x- S6 p - url: "www.runoob.com",
: o) s+ I+ S& z% G/ x+ C. M - alexa: "10000"
. D* a$ p& u6 @6 |+ z - },
1 C6 w( h' K `2 }5 j; P* V: G: ? - methods: {! {8 N! ^/ X- {$ N4 C O) f
- details: function() {$ H) G/ w( |* N2 f2 \5 G# f
- return this.site + " - 学的不仅是技术,更是梦想!";9 R8 n2 t' `3 L# r6 |' _" C% Y7 X( s. u
- }( `6 t( [, f2 v' ? I! {
- }" q% P) _7 c4 ]# b6 Y ?" z
- })
7 S, ?) A$ h( }2 X G- O* q - </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">% `# g" [0 c" I6 ^1 n' ~+ d# ]
- <h1>site : {{site}}</h1>
) D9 X7 W7 k' Q" u: R& ~) ^ - <h1>url : {{url}}</h1>
+ w& v2 x5 ?8 s# ~$ ^; W2 w% a - <h1>{{details()}}</h1>& v' B, d3 ] Q' q$ ~; e! ?. i
- </div>
复制代码当一个 Vue 实例被创建时,它向 Vue 的响应式系统中加入了其 data 对象中能找到的所有的属性。当这些属性的值发生改变时,html 视图将也会产生相应的变化。 - <div id="vue_det">9 t$ x! K6 ?; R" }, g
- <h1>site : {{site}}</h1>5 u, O r8 k4 U8 v6 B, C C
- <h1>url : {{url}}</h1>
5 f$ b( ]* R" R* K$ k! | - <h1>Alexa : {{alexa}}</h1># h6 v% e0 c- Y; k
- </div>
: k9 _7 R P, X7 R# _3 ] - <script type="text/javascript">: N* D: I E9 x4 B* _ t3 C+ R
- // 我们的数据对象0 _8 o' j1 q5 g1 b
- var data = { site: "菜鸟教程", url: "www.runoob.com", alexa: 10000}
4 a( N7 d; R" Q/ w7 ~4 s" ] - var vm = new Vue({, z! E) Y! N8 r/ ^
- el: '#vue_det',0 V2 H1 S9 l& k* u
- data: data
* m& `7 k: z' n: N- R1 M - })& p' J% u# R: j a
- // 它们引用相同的对象!
; X9 z, w E+ F/ I2 Z. O - document.write(vm.a === data.a) // true$ J: G( Q* T, C; r
- document.write("<br>")8 I3 [ a4 z" N7 z( l* W* b
- // 设置属性也会影响到原始数据! j& M6 i1 \( m7 i7 g+ D( h6 T
- vm.site = "Runoob"
0 B: ^0 x) ]1 R/ Y - document.write(data.site + "<br>") // Runoob4 l& i" q- z& A+ O) T
- # F [# K$ |" Q4 K' B6 j/ Z
- // ……反之亦然
- o4 E" r% B" V: S - data.alexa = 1234
`6 X! h& }$ B( k% [: q% I - document.write(vm.alexa) // 1234
) h9 I6 ?! r, {1 d- t/ A - </script>
复制代码除了数据属性,Vue 实例还提供了一些有用的实例属性与方法。它们都有前缀 $,以便与用户定义的属性区分开来。例如: - <div id="vue_det">
: S8 ]' M' h3 \) ~ - <h1>site : {{site}}</h1>4 x; y4 _( g% W# r" _4 L0 H5 d% B, A
- <h1>url : {{url}}</h1>3 b4 p% o1 b& S* w& \
- <h1>Alexa : {{alexa}}</h1>6 n) R o# S, ^, Y4 l
- </div> k# N& g) h" b: u
- <script type="text/javascript">
3 ^% S$ D2 C2 W, o; b - // 我们的数据对象
8 G. H; `8 n: V6 z - var data = { site: "菜鸟教程", url: "www.runoob.com", alexa: 10000}* g* S' b6 _( }! g: |
- var vm = new Vue({
; q H& d3 e( j( t2 Y* W3 X( ~# ^: x3 m - el: '#vue_det',( o8 ~1 L1 t E
- data: data
# H" h8 v! V1 [. X! s3 B% ` - })1 X6 z' a4 s1 Q$ m, t3 C$ z9 H
- 8 g: v4 X7 l( `" [
- document.write(vm.$data === data) // true
h6 N' V3 X! Q& c1 Y+ [ - document.write("<br>") // true
7 G% M9 U5 h) [" j. @0 s8 S1 d7 Y3 u - document.write(vm.$el === document.getElementById('vue_det')) // true+ G8 }( L# F% ~ B
- </script>
复制代码 % ?, t& Q( ]* C+ V' G% Y: T* p3 R" o' ?
% }8 `, F* z8 C9 ]: y* Q, G |