Vue.js教程之計(jì)算屬性
Vue.js 的內(nèi)聯(lián)表達(dá)式非常方便,但它最合適的使用場景是簡單的布爾操作或字符串拼接。如果涉及更復(fù)雜的邏輯,你應(yīng)該使用計(jì)算屬性。
計(jì)算屬性是用來聲明式的描述一個值依賴了其它的值。當(dāng)你在模板里把數(shù)據(jù)綁定到一個計(jì)算屬性上時(shí),Vue 會在其依賴的任何值導(dǎo)致該計(jì)算屬性改變時(shí)更新 DOM。這個功能非常強(qiáng)大,它可以讓你的代碼更加聲明式、數(shù)據(jù)驅(qū)動并且易于維護(hù)。
通常情況下,使用計(jì)算屬性會比使用過程式的$watch回調(diào)更合適。比如下面的例子:
<div id="demo">{{fullName}}</div>
var vm = new Vue({
data: {
firstName: 'Foo',
lastName: 'Bar',
fullName: 'Foo Bar'
}
})
vm.$watch('firstName', function (val) {
this.fullName = val + ' ' + this.lastName
})
vm.$watch('lastName', function (val) {
this.fullName = this.firstName + ' ' + val
})
上面的代碼是過程式的,并且比較笨重。對比一下計(jì)算屬性的版本:
var vm = new Vue({
el:'#demo',
data: {
firstName: 'Foo',
lastName: 'Bar'
},
computed: {
fullName: function () {
return this.firstName + ' ' + this.lastName
}
}
})
是不是感覺好多了?另外,你還可以為計(jì)算屬性提供一個 setter:
computed: {
fullName: {
// getter
get: function () {
return this.firstName + ' ' + this.lastName
},
// setter
set: function (newValue) {
var names = newValue.split(' ')
this.firstName = names[0]
this.lastName = names[names.length - 1]
}
}
}
計(jì)算屬性緩存
在 0.12.8 之前,計(jì)算屬性僅僅體現(xiàn)為一個取值的行為 —— 每次你訪問它的時(shí)候,getter 都會重新求值。在 0.12.8 中對此做了改進(jìn) —— 計(jì)算屬性的值會被緩存,只有在其某個反應(yīng)依賴改變才會重新計(jì)算。
設(shè)想我們有一個開銷很大的計(jì)算屬性 A,它需要循環(huán)一個大數(shù)組并且完成很多運(yùn)算。并且我們還有一個依賴 A 的計(jì)算屬性。如果沒有緩存,我們對 A 的 getter 不必要的過度調(diào)用就會導(dǎo)致潛在的性能問題。而有了緩存,A 的值會被緩存起來,除非其依賴發(fā)生了變化,這樣訪問它再多次也不會導(dǎo)致大量的不必要運(yùn)算了。
然而,我們還是應(yīng)該理解什么會被視為“反應(yīng)式依賴”:
var vm = new Vue({
data: {
msg: 'hi'
},
computed: {
example: {
return Date.now() + this.msg
}
}
})
在上面的例子中,計(jì)算屬性依賴 vm.msg。因?yàn)檫@是一個在 Vue 實(shí)例中被觀察的數(shù)據(jù)屬性,那么它就被視為了一個反應(yīng)式依賴。無論何時(shí) vm.msg 改變,vm.example 的值都會被重新計(jì)算。
然而,Date.now()并不是反應(yīng)式依賴,因?yàn)樗鼪]有和 Vue 的數(shù)據(jù)觀察系統(tǒng)發(fā)生任何關(guān)系。因此,當(dāng)你在程序中訪問vm.example時(shí),你會發(fā)現(xiàn)除非vm.msg觸發(fā)了一次重新計(jì)算,否則時(shí)間戳始終是相同的值。
有的時(shí)候你需要保留簡單獲取數(shù)據(jù)的模式,每次你訪問 vm.example 的時(shí)候都希望觸發(fā)重新計(jì)算。從 0.12.11 開始,你可以為一個特殊的計(jì)算屬性開關(guān)緩存支持:
computed: {
example: {
cache: false,
get: function () {
return Date.now() + this.msg
}
}
}
現(xiàn)在,每次你訪問 vm.example 的時(shí)候,時(shí)間戳都會及時(shí)更新。然而,要注意這只發(fā)生在 JavaScript 程序內(nèi)部訪問的時(shí)候,數(shù)據(jù)綁定還是依賴驅(qū)動的。當(dāng)你在模板中綁定一個 {{example}} 的計(jì)算屬性時(shí),DOM 只會在反應(yīng)式依賴改變時(shí)才會更新。
以上所述是小編給大家介紹的Vue.js教程之計(jì)算屬性,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時(shí)回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
- vue實(shí)現(xiàn)全選、反選功能
- 使用vue.js實(shí)現(xiàn)checkbox的全選和多個的刪除功能
- 利用Vue.js實(shí)現(xiàn)checkbox的全選反選效果
- vue2.0在table中實(shí)現(xiàn)全選和反選的示例代碼
- Vue自定義指令實(shí)現(xiàn)checkbox全選功能的方法
- vue.js實(shí)現(xiàn)的全選與全不選功能示例【基于elementui】
- vue計(jì)算屬性get和set用法示例
- Vue.js每天必學(xué)之計(jì)算屬性computed與$watch
- Vue computed計(jì)算屬性的使用方法
- Vue計(jì)算屬性的使用
- vue基于兩個計(jì)算屬性實(shí)現(xiàn)選中和全選功能示例
相關(guān)文章
vue3+typeScript穿梭框的實(shí)現(xiàn)示例
這篇文章主要介紹了vue3+typeScript穿梭框的實(shí)現(xiàn)示例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-12-12
Vue自定義render統(tǒng)一項(xiàng)目組彈框功能
這篇文章主要介紹了Vue自定義render統(tǒng)一項(xiàng)目組彈框功能,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-06-06
vue2.0 移動端實(shí)現(xiàn)下拉刷新和上拉加載更多的示例
本篇文章主要介紹vue2.0 移動端實(shí)現(xiàn)下拉刷新和上拉加載更多的示例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-04-04
Vue生命周期和鉤子函數(shù)的詳解與經(jīng)典面試題
Vue生命周期是指vue實(shí)例對象從創(chuàng)建之初到銷毀的過程,vue所有功能的實(shí)現(xiàn)都是圍繞其生命周期進(jìn)行的,下面這篇文章主要給大家介紹了關(guān)于Vue生命周期和鉤子函數(shù)的相關(guān)資料,需要的朋友可以參考下2021-10-10
vue中 process.env與process.VUE_CLI_SERVICE詳解
這篇文章主要介紹了vue中process.env與process.VUE_CLI_SERVICE的相關(guān)資料,本文結(jié)合實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-05-05
Vue3中provide和inject數(shù)據(jù)修改規(guī)則
在Vue3中,通過inject接收到的數(shù)據(jù)是否可以直接修改,取決于provide提供的值的類型和響應(yīng)式處理方式,本文給大家介紹Vue3中provide和inject數(shù)據(jù)修改規(guī)則,感興趣的朋友一起看看吧2025-04-04

