Vue計算屬性與監(jiān)視屬性詳細分析使用
計算屬性(computed)
計算屬性指的是通過一系列運算之后,最終得到一個值。這個動態(tài)計算出來的屬性值可以被模板結(jié)構(gòu)或methods方法使用,案例如下:
<div id="root">
R:<input type="text" v-model.number="r"><br>
G:<input type="text" v-model.number="g"><br>
B:<input type="text" v-model.number="b">
<div class="box" :style="{backgroundColor:rgb}">
{{rgb}}
</div>
<button @click="show">按鈕</button>
</div>
<script src="/vue/vue.js"></script>
<script>
const vm = new Vue({
el:'#root',
data:{
r:0 , g:0, b:0,
},
methods: {
show() {
console.log(this.rgb);
}
},
//所有計算屬性都要定義到computed節(jié)點之下
computed: {
// 計算屬性在定義的時候,要定義成“方法格式”,在這個方法中會生成好的rgb(x,x,x)的字符串
//實現(xiàn)了代碼的復(fù)用,只要計算屬性中依賴的數(shù)據(jù)變化了,則計算屬性會自動重新賦值
rgb() {
return `rgb(${this.r},${this.g},${this.b})`
}
}
})
</script>
使用名字動態(tài)改變實現(xiàn)計算屬性案例:
<div id="root">
<input type="text" v-model="firstname"><br>
<input type="text" v-model="lastname"><br>
全名:<span>{{fullname}}</span>
</div>
<script src="/vue/vue.js"></script>
<script>
const vm = new Vue({
el:"#root",
data:{
firstname:'張',
lastname:'三'
},
computed:{
fullname:{
//當(dāng)初次讀取fullname或所依賴的數(shù)據(jù)發(fā)生變化時,get被調(diào)用
get(){
console.log('get被調(diào)用了');
return this.firstname+'-'+this.lastname
},
//當(dāng)主動修改fullname時,set被調(diào)用
set(value){
console.log('set', value);
const arr = value.split('-');
this.firstname = arr[0]
this.lastname = arr[1]
}
}
}
})
</script>
計算屬性:
1.定義:要用的屬性不存在,要通過已有的屬性得來
2.原理:底層借助了Object.defineproperty方法提供的getter和setter
3.優(yōu)勢:與methods實現(xiàn)相比,內(nèi)部有緩存機制(復(fù)用),效率更高,調(diào)試方便
4.備注:計算屬性最終會出現(xiàn)在vm上,直接讀取使用即可;如果計算屬性要被修改,那必須寫set函數(shù)去響應(yīng)改變,且set中要引起計算時依賴的數(shù)據(jù)發(fā)生改變。
監(jiān)視屬性(watch)
watch監(jiān)視(偵聽)器允許開發(fā)者監(jiān)視數(shù)據(jù)的變化,從而針對數(shù)據(jù)的變化做特定的操作。
監(jiān)視的兩種方法
通過new Vue時傳入watch配置:
<div id="root">
<input type="text" v-model="name">
</div>
<script src="./vue.js"></script>
<script>
const vm = new Vue({
el:'#root',
data:{
name:''
},
//所有的偵 聽 器,都應(yīng)該被定義到watch節(jié)點下
watch:{
// 偵 聽 器本質(zhì)上是一個函數(shù),要監(jiān)視哪個數(shù)據(jù)的變化,就把數(shù)據(jù)名作為方法名即可
//newVal是“變化后的新值”,oldVal是“變化之前舊值”
name(newVal,oldVal){ //監(jiān)聽name值的變化
console.log("監(jiān)聽到了新值"+newVal, "監(jiān)聽到了舊值"+oldVal);
}
}
})
</script>
通過vm.$watch監(jiān)視:
<div id="root">
<h2>今天天氣很{{info}}</h2>
<button @click="changeWeather">切換天氣</button>
</div>
<script src="./vue.js"></script>
<script>
const vm = new Vue({
el:'#root',
data:{
isHot:true
},
computed:{
info(){
return this.isHot ? '炎熱' : '涼爽'
}
},
methods:{
changeWeather(){
this.isHot = !this.isHot
}
},
})
vm.$watch('info',{
handler(newVal,oldVal){
console.log('天氣被修改了', newVal, oldVal);
}
})
</script>
immediate選項
默認情況下,組件在初次加載完畢后不會調(diào)用watch偵 聽 器,如果想讓watch偵 聽 器立即被調(diào)用,則需要使用immediate選項,immediate的作用是控制偵 聽 器是否自動觸發(fā)一次,選項的默認值為:false
<div id="root">
<input type="text" v-model="name">
</div>
<script src="./vue.js"></script>
<script>
const vm = new Vue({
el:'#root',
data:{
name:'admin'
},
watch:{
//定義對象格式的偵 聽 器
name:{
handler(newVal,oldVal){
console.log(newVal, oldVal);
},
immediate:true
}
}
})
</script>
深度監(jiān)視
如果watch偵聽的是一個對象,如果對象中的屬性值發(fā)生了變化,則無法被監(jiān)聽到。此時需要使用deep選項,開啟深度監(jiān)聽,只要對象中任何一個屬性變化了,都會觸發(fā)“對象的偵 聽 器”。
<div id="root">
<input type="text" v-model="info.name">
</div>
<script src="./vue.js"></script>
<script>
const vm = new Vue({
el:'#root',
data:{
info:{
name:'admin'
}
},
watch:{
info: {
handler(newVal){
console.log(newVal);
},
//開啟深度監(jiān)聽
deep:true
}
}
})
</script>
如果想要偵聽的對象是子屬性的變化,則必須包裹一層單引號。
watch:{
"info.name"(newVal){
console.log(newVal);
}
}
總結(jié):
1)Vue中的watch默認不監(jiān)測對象內(nèi)部值的改變(一層)
2)配置deep:true可以監(jiān)測對象內(nèi)部值改變(多層)
3)Vue自身可以監(jiān)測對象內(nèi)部值的改變,但Vue提供的watch默認不可以
4)使用watch時根據(jù)數(shù)據(jù)的具體結(jié)構(gòu),決定是否采用深度監(jiān)視
watch能開啟異步任務(wù),案例如下:
<div id="root">
<input type="text" v-model="firstname"><br>
<input type="text" v-model="lastname"><br>
全名:<span>{{fullname}}</span>
</div>
<script src="/vue/vue.js"></script>
<script>
const vm = new Vue({
el:"#root",
data:{
firstname:'張',
lastname:'三',
fullname:'張-三'
},
//watch能開啟異步任務(wù)
watch:{
firstname(val){
setTimeout(()=>{
this.fullname = val + '-' + this.lastname
},1000)
},
lastname(val){
this.fullname = this.firstname+'-'+val
}
}
})
</script>
computed和watch之間的區(qū)別:
1.computed能完成的功能,watch都可以完成。
2.watch能完成的功能,computed不一定能完成,例如:watch可以進行異步操作。
隱性原則:
1.被Vue管理的函數(shù),最好寫成普通函數(shù),這樣this的指向才是vm或組件實例對象
2.不被Vue所管理的函數(shù)(定時器的回調(diào)函數(shù)、ajax的回調(diào)函數(shù)、Promise的回調(diào)函數(shù)),最好寫成箭頭函數(shù),這樣this的指向才是vm或組件實例對象。
到此這篇關(guān)于Vue計算屬性與監(jiān)視屬性詳細分析使用的文章就介紹到這了,更多相關(guān)Vue計算屬性與監(jiān)視屬性內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Vue中textarea自適應(yīng)高度方案的實現(xiàn)
本文主要介紹了Vue中textarea自適應(yīng)高度方案的實現(xiàn),文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-01-01
如何利用vue+element?ui實現(xiàn)好看的登錄界面
最近做了個最基礎(chǔ)的ElementUI登錄頁,適合新手查看,所以下面這篇文章主要給大家介紹了關(guān)于如何利用vue+element?ui實現(xiàn)好看的登錄界面的相關(guān)資料,需要的朋友可以參考下2022-05-05
Vue?quill-editor?編輯器使用及自定義toobar示例詳解
這篇文章主要介紹了Vue quill-editor編輯器使用及自定義toobar示例詳解,這里講解編輯器quil-editor的知識結(jié)合實例代碼給大家介紹的非常詳細,需要的朋友可以參考下2023-07-07
Vue中避免濫用this去讀取data中數(shù)據(jù)
這篇文章主要介紹了Vue中避免濫用this去讀取data中數(shù)據(jù)的的相關(guān)資料,幫助大家更好的理解和學(xué)習(xí)使用vue框架,感興趣的朋友可以了解下2021-03-03
Vue使用axios進行g(shù)et請求拼接參數(shù)的2種方式詳解
axios中post請求都是要求攜帶參數(shù)進行請求,這篇文章主要給大家介紹了關(guān)于Vue使用axios進行g(shù)et請求拼接參數(shù)的2種方式,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下2023-01-01
vue項目中使用Hbuilder打包app 設(shè)置沉浸式狀態(tài)欄的方法
這篇文章主要介紹了vue項目 使用Hbuilder打包app 設(shè)置沉浸式狀態(tài)欄的方法,本文通過實例代碼效果圖展示給大家介紹的非常詳細,具有一定的參考借鑒價值 ,需要的朋友可以參考下2018-10-10
使用Vue中 v-for循環(huán)列表控制按鈕隱藏顯示功能
這篇文章主要介紹了使用Vue中 v-for循環(huán)列表控制按鈕隱藏顯示功能,需要的朋友可以參考下2019-04-04

