<!DOCTYPE html>
<html>
<head>
<script src="https://unpkg.com/vue@2.4.2"></script>
<meta charset="utf-8" />
<title></title>
</head>
<body>
<div id="app-6">
<p v-once v-if="see">{{ message }}</p>
<p v-if="see">{{ reversedMessage }}</p>
<p v-if="see">{{ reversedMessages() }}</p>
<input v-model="message">
<ol>
<todo-item
v-for="item in groceryList"
v-bind:todo="item"
v-bind:key="item.id"
></todo-item>
</ol>
</div>
</body>
</html>
<script>
var app6;
window.onload = function () {
Vue.component('todo-item', {
template: '<li>{{todo.text}}</li>',
props:['todo']
})
app6 = new Vue({
el: '#app-6',
data: {
see: true,
groceryList: [
{ id: 0, text: '蔬菜' },
{ id: 1, text: '奶酪' },
{ id: 2, text: '隨便其他什么人吃的東西' }
],
message: 'Hello Vue!'
},
//計算屬性
computed: {
reversedMessage: function () {
return this.message.split('').reverse().join('')
}
},
//方法返回
methods: {
reversedMessages: function () {
return this.message.split('').reverse().join('')
}
}
})
}
</script>
注意 由於計算屬性與method 與data中的屬性都是保存在app6這個對象的一級屬性里面 所以如果重名 后定義的將會覆蓋前定義的對象
官方文檔解釋兩者的差別
我們可以將同一函數定義為一個 method 而不是一個計算屬性。對於最終的結果,兩種方式確實是相同的。然而,不同的是計算屬性是基於它們的依賴進行緩存的。計算屬性只有在它的相關依賴發生改變時才會重新求值。這就意味着只要 message 還沒有發生改變,多次訪問 reversedMessage 計算屬性會立即返回之前的計算結果,而不必再次執行函數。
這也同樣意味着下面的計算屬性將不再更新,因為 Date.now() 不是響應式依賴:
|
computed: {
now: function () {
return Date.now()
}
}
|
相比而言,只要發生重新渲染,method 調用總會執行該函數。
文檔地址 https://cn.vuejs.org/v2/guide/computed.html
