Vue.js 起步
每個 Vue 應用都需要通過例項化 Vue 來實現。
語法格式如下:
var vm = new Vue({ // 選項 })
接下來讓我們通過例項來看下 Vue 構造器中需要哪些內容:
例項
<div id="vue_det">
<h1>site : {{site}}</h1>
<h1>url : {{url}}</h1>
<h1>{{details()}}</h1>
</div>
<script type="text/javascript">
var vm = new Vue({
el: '#vue_det',
data: {
site: "入門教學",
url: "www.itread01.com",
alexa: "10000"
},
methods: {
details: function() {
return this.site + " - 學的不僅是技術,更是夢想!";
}
}
})
</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"> <h1>site : {{site}}</h1> <h1>url : {{url}}</h1> <h1>{{details()}}</h1> </div>
當一個 Vue 例項被建立時,它向 Vue 的響應式系統中加入了其 data 物件中能找到的所有的屬性。當這些屬性的值發生改變時,html 檢視將也會產生相應的變化。
例項
<div id="vue_det">
<h1>site : {{site}}</h1>
<h1>url : {{url}}</h1>
<h1>Alexa : {{alexa}}</h1>
</div>
<script type="text/javascript">
// 我們的資料物件
var data = https://www.itread01.com/vue2/{ site: "入門教學", url: "www.itread01.com", alexa: 10000}
var vm = new Vue({
el:'#vue_det',
data: data
})
// 它們引用相同的物件!
document.write(vm.site === data.site) // true
document.write("<br>")
// 設定屬性也會影響到原始資料
vm.site = "itread01"
document.write(data.site + "<br>") // itread01
// ……反之亦然
data.alexa = 1234
document.write(vm.alexa) // 1234
</script>
除了資料屬性,Vue 例項還提供了一些有用的例項屬性與方法。它們都有字首 $,以便與使用者定義的屬性區分開來。例如:
例項
<div id="vue_det">
<h1>site : {{site}}</h1>
<h1>url : {{url}}</h1>
<h1>Alexa : {{alexa}}</h1>
</div>
<script type="text/javascript">
// 我們的資料物件
var data = https://www.itread01.com/vue2/{ site: "入門教學", url: "www.itread01.com", alexa: 10000}
var vm = new Vue({
el:'#vue_det',
data: data
})
document.write(vm.$data =https://www.itread01.com/vue2/== data) // true
document.write("<br>")
document.write(vm.$el === document.getElementById('vue_det')) // true
</script>