我們在工作中常常需要監聽某一個屬性值的變化,這個時候我們就需要用到了監聽屬性watch,在這裡我總結watch屬性的三種場景使用希望對你有所幫助: 1.基礎版監聽: 場景如下:輸入框輸入你的年齡,如果年齡在0 15歲提示信息:你還是個小孩,如果年齡在 15 25歲,提示信息:你已經是個少年,如果年齡 ...
我們在工作中常常需要監聽某一個屬性值的變化,這個時候我們就需要用到了監聽屬性watch,在這裡我總結watch屬性的三種場景使用希望對你有所幫助:
1.基礎版監聽:
場景如下:輸入框輸入你的年齡,如果年齡在0-15歲提示信息:你還是個小孩,如果年齡在 15-25歲,提示信息:你已經是個少年,如果年齡在25歲以上,提示信息:你已經長大了。根據需求配合監聽屬性我們得到下麵的代碼:
<template>
<div id="app">
年齡:<input type="number" v-model="age"><br>
提示信息:<span>{{infoMsg}}</span>
</div>
</template>
<script>
export default {
data() {
return {
age: "",
infoMsg:""
}
},
watch:{
age:function(val,oldval){
if(val>0 && val<15){
this.infoMsg="你還是個小孩"
}else if(val>15 && val<25){
this.infoMsg="你已經是個少年"
}else{
this.infoMsg="你已經長大了"
}
}
}
}
</script>
這裡需要特別說明一下的是:堅挺屬性方法中的兩個參數分別代表的含義:第一個val是當面正在監聽的屬性的值,oldval是屬性改變之前的值,由於這是形參的原因,參數的名字可以自己定義,但是但是參數所代表的含義是不會變化的。
2.進階版監聽:
下麵我們改變一下需求:基礎規則不變,但是因為後臺資料庫的更改(畫個圈圈咀咒他)我們需要提交一個這樣的數據結構
data() {
return {
info: {
age: ""
},
infoMsg: ""
};
},
由於我們監聽的是對象info中的屬性age值的變化,所以我們需要使用到的是深度監聽,具體代碼如下:
<template>
<div id="app">
年齡:<input type="number" v-model="info.age"><br>
提示信息:<span>{{infoMsg}}</span>
</div>
</template>
<script>
export default {
data() {
return {
info: {
age: ""
},
infoMsg: ""
};
},
watch: {
info: {
handler: function(val, oldval) {
var that = this;
if (val.age > 0 && val.age < 15) {
that.infoMsg = "你還是個小孩";
} else if (val.age > 15 && val.age < 25) {
that.infoMsg = "你已經是個少年";
} else {
that.infoMsg = "你已經長大了";
}
},
deep: true
}
}
};
</script>
在這裡需要註意的有兩點:1,這裡的function不能使用箭頭函數替代,如果使用箭頭函數的話,this的指向會是全局。2,你會註意到這裡多加入一個屬性是deep,它的含義表示是否開啟深度監聽,如果開啟值為true,反之為false。
3.最高級監聽:
針對第二個案例不知道你有沒有發現一個問題:我們監聽的是一個對象裡面某個屬性的變化,但是如果當這個對象裡面有很多個值的時候,雖然也可以使用第二種方法進行監聽,但是這將會是對資源的一種極大的浪費,身為一個嚴謹的程式員(微笑臉),絕對不能允許這樣的事情發生,所以我們可以結合computed(計算屬性)對上面的代碼進行優化:
<template>
<div id="app">
年齡:<input type="number" v-model="info.age"><br>
提示信息:<span>{{infoMsg}}</span>
</div>
</template>
<script>
export default {
data() {
return {
info: {
age: "",
name: "",
hobit: ""
},
infoMsg: ""
};
},
computed: {
ageval: function() {
return this.info.age;
}
},
watch: {
ageval: {
handler: function(val, oldval) {
var that = this;
if (val > 0 && val < 15) {
that.infoMsg = "你還是個小孩";
} else if (val > 15 && val < 25) {
that.infoMsg = "你已經是個少年";
} else {
that.infoMsg = "你已經長大了";
}
},
deep: true
}
}
};
</script>
通過上面的我們看出,這次我們監聽的是計算屬性ageval,而計算屬性返回的則是info對象中age的值,與第二次的代碼進行比較我們可以發現兩次代碼中監聽的一個是對象info,一個是info對象中age的值,性能大大增強,這就是我們期待的結果了。