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: "IT研修",
url: "www.xuhuhu.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 = { site: "IT研修", url: "www.xuhuhu.com", alexa: 10000}
var vm = new Vue({
el: '#vue_det',
data: data
})
// 它們引用相同的對象!
document.write(vm.site === data.site) // true
document.write("<br>")
// 設置屬性也會影響到原始數據
vm.site = "zaixian"
document.write(data.site + "<br>") // zaixian
// ……反之亦然
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 = { site: "IT研修", url: "www.xuhuhu.com", alexa: 10000}
var vm = new Vue({
el: '#vue_det',
data: data
})
document.write(vm.$data === data) // true
document.write("<br>")
document.write(vm.$el === document.getElementById('vue_det')) // true
</script>