我看官方文檔上說:
computed
和methods
的區別是,computed
會基於它們的依賴進行緩存,如果資料無法改變則computed
刷新時不會重新執行,而methods
則會每次執行。
but我寫的例子並不是這樣(寫的是官方的例子)。
html:
<p id="app">
<p>{{methodsNow()}}</p>
<p>{{computedNow}}</p>
</p>
javascript:
new Vue({
el:'#app',
data:{
},
methods:{
methodsNow:function(){
return new Date().toLocaleString();
}
},
computed:{
computedNow:function(){
return new Date().toLocaleString();
}
}
});
大家來探討一下,我是不是哪裡寫錯了?
你的例子對於描述二者不同這點上,沒有幫助。給你看這個例子:JSFiddle
你這樣測試下就明白了
html:
javascript:
結果你發現computedNow執行了一次,methodsNow執行了兩次