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>