top
Loading...
Vue.js 起步

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

嘗試一下 »
北斗有巢氏 有巢氏北斗