<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
<script src="https://cdn.staticfile.org/vue/2.4.2/vue.min.js"></script>
</head>
<body>
<div id="example">
<p>{{ nowComputed }}</p>
<p>{{ nameComputed }}</p>
<p>{{ ageComputed }}</p>
<input v-model="name">
<p>{{ nowMethods() }}</p>
<p>{{ nameMethods() }}</p>
<p>{{ ageMethods() }}</p>
</div>
<!--
1.兩者的執行結果是完全相同的
2.計算屬性是基於他們的依賴進行緩存的,只有在相關依賴發生改變時,他們纔會重新求值,
也就是說,只要他的依賴沒有發生變化,那麼每次訪問的時候計算屬性都會立即返回之前的計算結果,不再執行函數
3.每次觸發重新渲染時,調用方法將總會再次執行函數
4.上方兩個例子,計算屬性將總會返回相同值,而方法則不會
-->
<script>
var vm = new Vue({
el: '#example',
data: {
message: 'Hello',
name: 'xq',
age: "16"
},
computed: {
nowComputed: function () {
console.log("---------------- nowComputed")
return Date.now()
},
nameComputed: function () {
console.log(this.name + "---------------- nameComputed")
return "xq nameComputed"
},
ageComputed: function () {
console.log(this.age + "---------------- ageComputed")
return "18 ageComputed"
}
},
methods: {
nowMethods: function () {
console.log("============== nowMethods")
return Date.now()
},
nameMethods: function () {
console.log(this.name + "============== nameMethods")
return "xq nameMethods"
},
ageMethods: function () {
console.log(this.age + "============== ageMethods")
return "18 ageMethods"
}
}
})
</script>
</body>
</html>
vue :計算屬性computed 與方法methods區別
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.