詳解vue 計算屬性與方法跟偵聽器區(qū)別(面試考點)
計算屬性
模板內(nèi)的表達式非常便利,但是設計它們的初衷是用于簡單運算的。在模板中放入太多的邏輯會讓模板過重且難以維護。例如:
<div id="example">
{{ message.split('').reverse().join('') }}
</div>
在這個地方,模板不再是簡單的聲明式邏輯。你必須看一段時間才能意識到,這里是想要顯示變量 message 的翻轉(zhuǎn)字符串。當你想要在模板中多次引用此處的翻轉(zhuǎn)字符串時,就會更加難以處理。
所以,對于任何復雜邏輯,你都應當使用計算屬性。
基礎例子
<div id="app">
{{fullName}}
</div>
var vm = new Vue({
el: '#app',
data: {
firstName: "王",
lastName: "小智",
age: 28
},
// 計算屬性
computed: {
fullName: function () {
console.log("計算了一次")
return this.firstName + " " + this.lastName
}
}
})
結(jié)果:
王小智
然后我們通過瀏覽器改變age屬性的值,讓頁面重新渲染:

大家可以看到,我們改變了age值計算屬性的方法沒有被調(diào)用,那如果計算屬性的值發(fā)生了改變,如lastName或者firstName改變,打印結(jié)果又會怎么樣呢?

大家可以看到,當他依賴的發(fā)生變化的時候,計算屬性會重新計算一次。
計算屬性緩存 vs 方法
你可能已經(jīng)注意到我們可以通過在表達式中調(diào)用方法來達到同樣的效果:
<p>Reversed message: "{{ fullName() }}"</p>
// 在組件中
methods: {
fullName: function () {
console.log("計算了一次")
return this.firstName + " " + this.lastName;
}
}
結(jié)果:
王小智
同樣參照上面,我們通過瀏覽器改變age屬性的值,讓頁面重新渲染:

可以看出,我們頁面只要重新渲染,方法都會執(zhí)行一次,而計算屬性只有在它的相關依賴發(fā)生改變時才會重新求值。
我們?yōu)槭裁葱枰彺??假設我們有一個性能開銷比較大的的計算屬性 A,它需要遍歷一個巨大的數(shù)組并做大量的計算。然后我們可能有其他的計算屬性依賴于A 。如果沒有緩存,我們將不可避免的多次執(zhí)行 A 的 getter!如果你不希望有緩存,請用方法來替代。
計算屬性 vs 偵聽屬性
你可能已經(jīng)注意到我們還可以通過偵聽屬性達到同樣的效果:
var vm = new Vue({
el: '#app',
data: {
firstName: "王",
lastName: "小智",
age: 28,
fullName
},
// 計算屬性
watch: {
firstName: function () {
console.log("計算了一次");
this.fullNmae = this.firstName + this.lastName;
},
lastName: function () {
console.log("計算了一次")
this.fullNmae = this.firstName + this.lastName;
}
}
})
結(jié)果:
王小智
同樣參照上面,我們通過瀏覽器改變age屬性的值,讓頁面重新渲染:

大家可以看到,和fullname不相關的改變,fullName沒有變化,跟計算屬性類似,會有緩存,只有在它的相關依賴發(fā)生改變時才會重新求值,將它與計算屬性的版本進行比較,好得多了,不是嗎?
當你有一些數(shù)據(jù)需要隨著其它數(shù)據(jù)變動而變動時,你很容易濫用 watch——特別是如果你之前使用過
AngularJS。然而,通常更好的做法是使用計算屬性而不是命令式的 watch 回調(diào)。
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
VUE3.2項目使用Echarts5.4詳細步驟總結(jié)
Vue3.2是一款非常流行的JavaScript框架,它讓在前端領域開發(fā)變得更加的便捷,下面這篇文章主要給大家介紹了關于VUE3.2項目使用Echarts5.4的相關資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下2023-06-06
vue實現(xiàn)類似淘寶商品評價頁面星級評價及上傳多張圖片功能
最近在寫一個關于vue的商城項目,然后集成在移動端中,開發(fā)需求中有一界面,類似淘寶商城評價界面!接下來通過本文給大家分享vue實現(xiàn)類似淘寶商品評價頁面星級評價及上傳多張圖片功能,需要的朋友參考下吧2018-10-10
基于Vue3+TypeScript實現(xiàn)圖片預覽組件
在現(xiàn)代的 Web 應用中,圖片預覽是一個常見的需求,本文將介紹如何使用 Vue3 和 TypeScript 開發(fā)一個圖片預覽組件,支持展示單張或多張圖片,并提供了豐富的配置選項,需要的朋友可以參考下2024-04-04
vue.js綁定事件監(jiān)聽器示例【基于v-on事件綁定】
這篇文章主要介紹了vue.js綁定事件監(jiān)聽器的方法,結(jié)合實例形式分析了vue.js基于v-on事件綁定響應鼠標點擊相關操作技巧,需要的朋友可以參考下2018-07-07
詳解從Vue.js源碼看異步更新DOM策略及nextTick
本篇文章主要介紹了從Vue.js源碼看異步更新DOM策略及nextTick,具有一定的參考價值,感興趣的小伙伴們可以參考一2017-10-10

