VUE 的計(jì)算屬性可以使用緩存,提高頁(yè)面性能。
計(jì)算屬性會(huì)緩存它的一部分內(nèi)容,只有全部相關(guān)的數(shù)據(jù)發(fā)生變化時(shí),才會(huì)重新計(jì)算。使用計(jì)算屬性的好處是可以將復(fù)雜的邏輯拆分成簡(jiǎn)單的部分,同時(shí)保留可讀性和易于維護(hù)性。
computed: {
getCount() {
console.log('getCount')
return this.numbers.reduce((total, num) =>total + num, 0)
}
}
在上述代碼中,計(jì)算屬性 `getCount` 會(huì)對(duì) `this.numbers` 數(shù)組中的所有數(shù)字進(jìn)行求和。如果其中的某一項(xiàng)變化了,那么這個(gè)計(jì)算屬性會(huì)重新計(jì)算。但如果數(shù)組中的某一項(xiàng)的值沒(méi)有發(fā)生變化,那么計(jì)算屬性會(huì)直接返回之前緩存的結(jié)果。
在模板中調(diào)用計(jì)算屬性是很容易的:
<template>
<div>
<p>Number Count: {{ getCount }}</p>
</div>
</template>
這樣做的好處就在于,當(dāng)數(shù)組很大時(shí),計(jì)算屬性只會(huì)在必要的情況下重新計(jì)算,而不會(huì)每次都執(zhí)行。同時(shí),它也可以更好地隔離和組織復(fù)雜邏輯。
當(dāng)然,計(jì)算屬性的緩存僅僅是基于它所依賴的數(shù)據(jù)的變化而重新計(jì)算。如果你想刷新緩存,可以把使用計(jì)算屬性的屬性設(shè)為新值,或者是重載整個(gè)組件。
methods: {
reloadData() {
this.reload = true
}
}
使用上面的代碼可以強(qiáng)制重新計(jì)算整個(gè)組件。當(dāng) `reload` 屬性的值更新時(shí),所有的計(jì)算屬性都會(huì)被重新計(jì)算。
總的來(lái)說(shuō),計(jì)算屬性的緩存機(jī)制可以很好地提高頁(yè)面性能,同時(shí)還可以更好地組織和管理代碼。