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

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

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

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

大家可以看到,和fullname不相關(guān)的改變,fullName沒(méi)有變化,跟計(jì)算屬性類似,會(huì)有緩存,只有在它的相關(guān)依賴發(fā)生改變時(shí)才會(huì)重新求值,將它與計(jì)算屬性的版本進(jìn)行比較,好得多了,不是嗎?
當(dāng)你有一些數(shù)據(jù)需要隨著其它數(shù)據(jù)變動(dòng)而變動(dòng)時(shí),你很容易濫用 watch——特別是如果你之前使用過(guò)
AngularJS。然而,通常更好的做法是使用計(jì)算屬性而不是命令式的 watch 回調(diào)。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
vue+openlayers+nodejs+postgis實(shí)現(xiàn)軌跡運(yùn)動(dòng)效果
使用postgres(postgis)數(shù)據(jù)庫(kù)以及nodejs作為后臺(tái),vue和openlayers做前端,openlayers使用http請(qǐng)求通過(guò)nodejs從postgres數(shù)據(jù)庫(kù)獲取數(shù)據(jù),這篇文章主要介紹了vue+openlayers+nodejs+postgis實(shí)現(xiàn)軌跡運(yùn)動(dòng),需要的朋友可以參考下2024-05-05
Vue項(xiàng)目中安裝使用axios全過(guò)程
這篇文章主要介紹了Vue項(xiàng)目中安裝使用axios全過(guò)程,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-10-10
ElementUI時(shí)間選擇器限制選擇范圍disabledData的使用
本文主要介紹了ElementUI時(shí)間選擇器限制選擇范圍disabledData的使用,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2022-06-06
詳解vue-meta如何讓你更優(yōu)雅的管理頭部標(biāo)簽
這篇文章主要介紹了詳解vue-meta如何讓你更優(yōu)雅的管理頭部標(biāo)簽,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-01-01
關(guān)于vite proxy跨域問(wèn)題的解決
這篇文章主要介紹了關(guān)于vite proxy跨域問(wèn)題的解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-03-03
vue動(dòng)態(tài)綁定background的方法
background是background-color,background-image,background-repeat,background-attachment,background-position,background-size等屬性的縮寫,本文我用動(dòng)態(tài)綁定background-image來(lái)舉例,感興趣的朋友跟隨小編一起看看吧2023-10-10
vue3中el-table實(shí)現(xiàn)多表頭并表格合并行或列代碼示例
這篇文章主要給大家介紹了關(guān)于vue3中el-table實(shí)現(xiàn)多表頭并表格合并行或列的相關(guān)資料,文中通過(guò)代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用vue具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2024-02-02
vue項(xiàng)目刷新當(dāng)前頁(yè)面的三種方式(重載當(dāng)前頁(yè)面數(shù)據(jù))
這篇文章主要介紹了vue項(xiàng)目刷新當(dāng)前頁(yè)面的三種方式(重載當(dāng)前頁(yè)面數(shù)據(jù)),本文結(jié)合實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-01-01

