Vue computed計(jì)算屬性總結(jié)記錄
前言
Vue中的計(jì)算屬性(comupted)是一個(gè)非常常用的技術(shù),如果使用得當(dāng),可以很優(yōu)雅的解決傳統(tǒng)方式較為復(fù)雜的問題,這篇文章以近期使用的computed為例,對(duì)computed進(jìn)行簡(jiǎn)要介紹。
一、計(jì)算屬性介紹
計(jì)算屬性本質(zhì)上是一個(gè)方法,寫在computed:{}配置項(xiàng)里面,可以當(dāng)做屬性來使用。能使用計(jì)算屬性的場(chǎng)景使用模板語(yǔ)法也同樣能夠?qū)崿F(xiàn),不過可能較為復(fù)雜,而計(jì)算屬性存在的意義在于使得模板語(yǔ)法更加簡(jiǎn)介。因此,對(duì)于復(fù)雜邏輯的計(jì)算結(jié)果需要被緩存,再次利用的情況下都需要使用計(jì)算屬性。
二、使用步驟
1.template中綁定計(jì)算屬性
<el-form-item label="類型" prop="type"> <el-radio v-model="pieType" :label="'ring'">環(huán)形</el-radio> <el-radio v-model="pieType" :label="'circle'">圓形</el-radio> </el-form-item>
我這里在form表單中type類型的表單項(xiàng)中使用了計(jì)算屬性pieType
2.script中定義計(jì)算屬性
computed:{ pieType:{ set(val){ if (val === 'ring'){ this.$set(this.curChart.option.series[0], 'radius', ['60%', '80%']) }else if (val === 'circle'){ this.$set(this.curChart.option.series[0], 'radius', '80%') } }, get(){ if (this.curChart.option.series[0].radius === '80%'){ return 'circle' }else if (JSON.stringify(this.curChart.option.series[0].radius) === JSON.stringify(['60%', '80%'])){ return 'ring' } } } },
在這個(gè)示例中,我想要實(shí)現(xiàn)如下效果:當(dāng) this.curChart.option.series[0].radius值為 '80%'時(shí),form表單中顯示餅狀圖的類型為環(huán)形圖,當(dāng) this.curChart.option.series[0].radius值為[‘60%’, ‘80%’],form表單中顯式餅狀圖類型為圓形。因此在get時(shí),判斷radius是哪種類型,返回對(duì)應(yīng)的ring或者circle值;在set時(shí),根據(jù)pieType值,更改this.curChart.option.series[0]的radius值。按照這個(gè)思路,你也可以進(jìn)行顯示值和存儲(chǔ)值的切換。
3.計(jì)算屬性的配置項(xiàng)
- get(): 必須寫,且無參。當(dāng)初次讀取計(jì)算屬性或者計(jì)算屬性依賴的數(shù)據(jù)發(fā)生變化時(shí)被調(diào)用,get()方法的返回值就是計(jì)算屬性的值。
- set(): 可寫,接受一個(gè)可選參數(shù),該參數(shù)是計(jì)算屬性被修改之后的值。當(dāng)計(jì)算屬性被修改時(shí)調(diào)用,例如在上面的例子中,切換類型的單選按鈕,會(huì)導(dǎo)致計(jì)算屬性被修改,進(jìn)而執(zhí)行set()方法,對(duì)this.curChart.option.series[0]的radius值進(jìn)行賦值。
4.計(jì)算屬性的簡(jiǎn)寫
當(dāng)計(jì)算屬性只需要get值,也就是計(jì)算屬性本身不會(huì)變化,只會(huì)受到別的數(shù)據(jù)影響而變化時(shí),采用簡(jiǎn)寫方式:
data: { firstName: '熊', lastName: '大' }, computed:{ //此處簡(jiǎn)寫方式一: fullName:{ get(){ return this.firstName +'-'+ this.lastName } } //此處簡(jiǎn)寫方式二: fullName(){ return this.firstName +'-'+ this.lastName } }
總結(jié)
本文對(duì)vue的計(jì)算屬性進(jìn)行總結(jié)記錄,并根據(jù)最近用到computed的地方進(jìn)行詳細(xì)舉例說明,此外還介紹了計(jì)算屬性的簡(jiǎn)寫方式,get(), set()方法的作用和調(diào)用方式。
到此這篇關(guān)于Vue computed計(jì)算屬性總結(jié)記錄的文章就介紹到這了,更多相關(guān)Vue computed計(jì)算屬性內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Vue唯一可以更改vuex實(shí)例中state數(shù)據(jù)狀態(tài)的屬性對(duì)象Mutation的講解
今天小編就為大家分享一篇關(guān)于Vue唯一可以更改vuex實(shí)例中state數(shù)據(jù)狀態(tài)的屬性對(duì)象,小編覺得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來看看吧2019-01-01element el-tree組件的動(dòng)態(tài)加載、新增、更新節(jié)點(diǎn)的實(shí)現(xiàn)
這篇文章主要介紹了element el-tree組件的動(dòng)態(tài)加載、新增、更新節(jié)點(diǎn)的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-02-02vue-resourse將json數(shù)據(jù)輸出實(shí)例
這篇文章主要為大家詳細(xì)介紹了vue-resourse將json數(shù)據(jù)輸出實(shí)例,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-03-03詳解vuex中mapState,mapGetters,mapMutations,mapActions的作用
這篇文章主要介紹了vuex中mapState,mapGetters,mapMutations,mapActions的作用,需要的朋友可以參考下2018-04-04Vue.js中關(guān)于偵聽器(watch)的高級(jí)用法示例
Vue.js 提供了一個(gè)方法 watch,它用于觀察Vue實(shí)例上的數(shù)據(jù)變動(dòng)。下面這篇文章主要給大家介紹了關(guān)于Vue.js中關(guān)于偵聽器(watch)的高級(jí)用法的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考下2018-05-05Vue中created和mounted使用場(chǎng)景分析
vue.js中created方法是一個(gè)生命周期鉤子函數(shù),一般可以在created函數(shù)中調(diào)用ajax獲取頁(yè)面初始化所需的數(shù)據(jù),這篇文章主要介紹了Vue中created和mounted使用場(chǎng)景分析,需要的朋友可以參考下2023-05-05vue-model實(shí)現(xiàn)簡(jiǎn)易計(jì)算器
這篇文章主要為大家詳細(xì)介紹了vue-model實(shí)現(xiàn)簡(jiǎn)易計(jì)算器,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-08-08