Vue計(jì)算屬性的使用
我們都知道在Vue構(gòu)造函數(shù)的參數(shù)對(duì)象中有一個(gè)【data】屬性,該屬性值是一個(gè)對(duì)象,該對(duì)象是對(duì)數(shù)據(jù)的代理,是一個(gè)鍵值對(duì)并且時(shí)刻與頁面表現(xiàn)是一致的,但是這里面只能是簡(jiǎn)單的鍵值對(duì),不能擁有業(yè)務(wù)邏輯,并且由于【data】中的屬性屬于同一個(gè)生命周期,所以如果我們需要某一個(gè)屬性是依賴于另外一個(gè)屬性時(shí),在【data】中是做不到的,于是Vue為我們提供了【計(jì)算屬性】
一、計(jì)算屬性
1.1 概述
計(jì)算屬性歸根結(jié)底也是屬性,它也是跟表現(xiàn)層是時(shí)刻同步的,雖然我們可以在插值中對(duì)數(shù)據(jù)進(jìn)行各種處理,但是插值中的表達(dá)式處理畢竟只能用于簡(jiǎn)單的運(yùn)算,不能擁有太多的業(yè)務(wù)邏輯。
<body>
<div id="app">
<h1>{{name.toUpperCase()}}</h1>
<!-- <h1>BLUE</h1> -->
</div>
</body>
<script>
let vm = new Vue({
el: "#app",
data: {
name: 'blue'
}
})
</script>
上面代碼是我們熟悉的在插值中使用表達(dá)式,但是這里面我們不能寫入業(yè)務(wù)代碼。
1.2 計(jì)算屬性語法
在構(gòu)造函數(shù)的參數(shù)對(duì)象中有一個(gè)【computed】屬性,該屬性就是用于定義計(jì)算屬性的,該對(duì)象中的【鍵】也就是我們的計(jì)算屬性,與【data】不同的是,計(jì)算屬性的鍵值是一個(gè)【擁有返回值的函數(shù)】,該函數(shù)中可以訪問到【data】中的所有屬性。
<body>
<div id="app">
<h1>{{rs}}</h1>
<!-- <h1>BLUE LOVE PINK</h1> -->
</div>
</body>
<script>
let vm = new Vue({
el: "#app",
data: {
hs: 'BLUE',
wf: "PINK"
},
computed: {
rs:function(){
return `${this.hs} LOVE ${this.wf}`
}
}
})
</script>
上面代碼屬性【rs】是定義的一個(gè)計(jì)算屬性,該屬性值是通過【data】中的兩個(gè)屬性值計(jì)算得到,返回一個(gè)拼接的字符串(這兒使用了ES6的【模板字符串】)并且當(dāng)【data】中的相關(guān)值變化之后,【rs】屬性都會(huì)進(jìn)行重新計(jì)算。
可能剛開始對(duì)計(jì)算屬性會(huì)有些疑惑,比如上面的例子我把代碼寫成下面這樣子也是可以的
<body>
<div id="app">
<h1>{{hs}} LOVE {{wf}}</h1>
<!-- <h1>BLUE LOVE PINK</h1> -->
</div>
</body>
<script>
let vm = new Vue({
el: "#app",
data: {
hs: 'BLUE',
wf: "PINK"
}
})
</script>
上面的代碼運(yùn)行效果和我們使用計(jì)算屬性的效果是一樣的,但是這樣的寫法只適用于簡(jiǎn)單的處理,【計(jì)算屬性可以處理更復(fù)雜的業(yè)務(wù)邏輯】,比如我們根據(jù)【data】中的一個(gè)屬性值進(jìn)行數(shù)據(jù)請(qǐng)求用于構(gòu)建一個(gè)屬性,我們就必須使用計(jì)算屬性了。
【注意!!】計(jì)算屬性雖然是一個(gè)方法,但是在Vue內(nèi)部會(huì)被翻譯成一個(gè)屬性,我們可以使用實(shí)例【vm.rs】訪問到數(shù)據(jù)的。
1.3 計(jì)算屬性和過濾器的比較
如果用于對(duì)【data】中【單個(gè)】屬性的【簡(jiǎn)單】處理,推薦使用過濾器,但是如果一個(gè)值使用了【data】中至少2個(gè)值或者對(duì)一個(gè)值進(jìn)行復(fù)雜處理,那么就推薦使用計(jì)算屬性了。
<body>
<div id="app">
<h1>{{hs | lover}}</h1>
<!-- <h1>BLUE LOVE PINK</h1> -->
</div>
</body>
<script>
let vm = new Vue({
el: "#app",
data: {
hs: 'BLUE',
},
filters: {
lover(value){
return `${value} LOVE PINK`
}
}
})
</script>
上面代碼就使用了一個(gè)【data】屬性值做簡(jiǎn)單的處理,所以使用過濾器,而且也發(fā)現(xiàn)了過濾字符串“LOVE PINK”是不可變的。
1.4 計(jì)算屬性和Methods的比較
計(jì)算屬性就是為了定屬性的時(shí)候處理復(fù)雜的業(yè)務(wù)邏輯,而且在插值中我們可以使用表達(dá)式,那么我們是否可以通過使用在插值中調(diào)用一個(gè)有返回值的函數(shù)呢?它和計(jì)算屬性又有什么區(qū)別呢?
<body>
<div id="app">
<h1>{{rs}}</h1>
<!-- <h1>EULB</h1> -->
</div>
</body>
<script>
let vm = new Vue({
el: "#app",
data: {
name: 'BLUE',
},
computed: {
rs: function () {
return [...this.name].reverse().join('');
}
}
})
</script>
上面代碼將數(shù)據(jù)進(jìn)行反向處理(使用了【ES6數(shù)組字符串?dāng)U展】 ),當(dāng)我們改變name的值的時(shí)候,計(jì)算屬性【rs】會(huì)跟著改變。下面我們將它改成一個(gè)方法結(jié)合插值表達(dá)式進(jìn)行處理,看看區(qū)別。
<body>
<div id="app">
<h1>{{ rs() }}</h1>
<!-- <h1>EULB</h1> -->
</div>
</body>
<script>
let vm = new Vue({
el: "#app",
data: {
name: 'BLUE',
},
methods: {
rs() {
return [...this.name].reverse().join('');
}
}
})
</script>
上面代碼將計(jì)算屬性改成了一個(gè)方法結(jié)合插值表達(dá)式,發(fā)現(xiàn)效果和計(jì)算屬性沒差別,改變name的值的時(shí)候頁面也刷新了。那是不是這兩者就真的沒區(qū)別呢,答案當(dāng)然是否定的,如果沒有區(qū)別干嘛還有計(jì)算屬性的存在。
【計(jì)算屬性是基于依賴進(jìn)行緩存的】,只有計(jì)算屬性的依賴發(fā)生改變時(shí)才會(huì)重新求值,也就是說如果依賴沒有發(fā)生改變,那么計(jì)算屬性會(huì)立刻返回之前的計(jì)算結(jié)果,假如我們有一個(gè)性能開銷比較大的的計(jì)算屬性 A ,它需要遍歷一個(gè)極大的數(shù)組和做大量的計(jì)算。然后我們可能有其他的計(jì)算屬性依賴于 A 。如果沒有緩存,我們將不可避免的多次執(zhí)行 A 的 getter!如果你不希望有緩存,請(qǐng)用 method 替代。
1.5 計(jì)算屬性和Watch的比較
我們發(fā)現(xiàn)計(jì)算屬性會(huì)監(jiān)聽依賴,如果依賴發(fā)生變化則會(huì)從新計(jì)算屬性,那么【監(jiān)聽器】也有這么一個(gè)功能,那么我們應(yīng)該在什么時(shí)候使用【計(jì)算屬性】,什么時(shí)候使用【監(jiān)聽器】呢?
<body>
<div id="app">
<h1>{{fullName}}</h1>
</div>
</body>
<script>
let vm = new Vue({
el: "#app",
data: {
firstName: 'Jack',
lastName: 'Blue',
fullName: 'Jack Blue'
},
watch: {
firstName: function (val) {
this.fullName = val + ' ' + this.lastName
},
lastName: function (val) {
this.fullName = this.firstName + ' ' + val
}
}
})
</script>
上面代碼中我們監(jiān)聽firstName和lastName用于構(gòu)建fullName,效果很好,當(dāng)firstName和lastName任意一個(gè)值改變的時(shí)候fullName都會(huì)隨之改變。下面我們看一下計(jì)算屬性的寫法
<body>
<div id="app">
<h1>{{fullName}}</h1>
<!-- <h1>Jack Blue</h1> -->
</div>
</body>
<script>
let vm = new Vue({
el: "#app",
data: {
firstName: 'Jack',
lastName: 'Blue',
},
computed: {
fullName() {
return this.firstName + ' ' + this.lastName
}
}
})
</script>
上面代碼使用計(jì)算屬性的方式進(jìn)行了改造,fullName 依賴 firstName和 lastName 兩個(gè)屬性,當(dāng)這兩個(gè)屬性任意一個(gè)發(fā)生變化,fullname都會(huì)重新進(jìn)行計(jì)算。但是計(jì)算屬性是不是簡(jiǎn)潔了很多呢!
【總結(jié)?。 慨?dāng)一個(gè)屬性需要依賴多個(gè)【data】中的屬性時(shí),建議使用計(jì)算屬性,如果我們不是對(duì)屬性進(jìn)行操作,只是單純的依據(jù)【data】中的某個(gè)值變化后做一些【非屬性操作】時(shí)或者是在數(shù)據(jù)變化響應(yīng)時(shí),【執(zhí)行異步操作或開銷較大的操作】(比如:將變化后的值存入數(shù)據(jù)庫,而不是改變其他屬性)就使用Watch。
1.6 計(jì)算屬性的setter
上面我們是使用的計(jì)算屬性都是用于對(duì)計(jì)算屬性的取值,計(jì)算屬性默認(rèn)頁只給了【getter】,但是在需要的時(shí)候我們可以人為的添加【setter】
<body>
<div id="app">
<h1>{{fullName}}</h1>
<!-- <h1>Jack Blue</h1> -->
</div>
</body>
<script>
let vm = new Vue({
el: "#app",
data: {
firstName: 'Jack',
lastName: 'Blue',
},
computed: {
fullName: {
//getter
get() {
return this.firstName + ' ' + this.lastName
},
//setter
set(newValue) {
var names = newValue.split(' ')
this.firstName = names[0]
this.lastName = names[names.length - 1]
}
}
}
})
</script>
上面代碼定義了計(jì)算屬性的一個(gè)setter,注意當(dāng)需要定義setter的時(shí)候語法上面是有區(qū)別的。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
vue created鉤子函數(shù)與mounted鉤子函數(shù)的用法區(qū)別
這篇文章主要介紹了vue created鉤子函數(shù)與mounted鉤子函數(shù)的用法區(qū)別,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2020-11-11
vue發(fā)送驗(yàn)證碼計(jì)時(shí)器防止刷新實(shí)現(xiàn)詳解
這篇文章主要為大家介紹了vue發(fā)送驗(yàn)證碼計(jì)時(shí)器防止刷新實(shí)現(xiàn)詳解,<BR>有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-03-03
vite+vue3+ts項(xiàng)目新建以及解決遇到的問題
vite是一個(gè)基于Vue3單文件組件的非打包開發(fā)服務(wù)器,它具有快速的冷啟動(dòng),不需要等待打包操作,下面這篇文章主要給大家介紹了關(guān)于vite+vue3+ts項(xiàng)目新建以及解決遇到的問題的相關(guān)資料,需要的朋友可以參考下2023-06-06
vuex模塊獲取數(shù)據(jù)及方法的簡(jiǎn)單示例
Vuex是一個(gè)專為Vue.js應(yīng)用程序開發(fā)的狀態(tài)管理模式,它采用集中式存儲(chǔ)管理應(yīng)用的所有組件的狀態(tài),并以相應(yīng)的規(guī)則保證狀態(tài)以一種可預(yù)測(cè)的方式發(fā)生變化,下面這篇文章主要給大家介紹了關(guān)于vuex模塊獲取數(shù)據(jù)及方法的相關(guān)資料,需要的朋友可以參考下2023-03-03
vue使用transition組件動(dòng)畫效果的實(shí)例代碼
這篇文章主要介紹了vue使用transition組件動(dòng)畫效果的實(shí)例代碼,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-01-01

