詳解vue2.0監(jiān)聽屬性的使用心得及搭配計(jì)算屬性的使用
我們在工作中常常需要監(jiān)聽某一個(gè)屬性值的變化,這個(gè)時(shí)候我們就需要用到了監(jiān)聽屬性watch,在這里我總結(jié)watch屬性的三種場景使用希望對(duì)你有所幫助:
1.基礎(chǔ)版監(jiān)聽:
場景如下:輸入框輸入你的年齡,如果年齡在0-15歲提示信息:你還是個(gè)小孩,如果年齡在 15-25歲,提示信息:你已經(jīng)是個(gè)少年,如果年齡在25歲以上,提示信息:你已經(jīng)長大了。根據(jù)需求配合監(jiān)聽屬性我們得到下面的代碼:
<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="你還是個(gè)小孩"
}else if(val>15 && val<25){
this.infoMsg="你已經(jīng)是個(gè)少年"
}else{
this.infoMsg="你已經(jīng)長大了"
}
}
}
}
</script>
這里需要特別說明一下的是:堅(jiān)挺屬性方法中的兩個(gè)參數(shù)分別代表的含義:第一個(gè)val是當(dāng)面正在監(jiān)聽的屬性的值,oldval是屬性改變之前的值,由于這是形參的原因,參數(shù)的名字可以自己定義,但是但是參數(shù)所代表的含義是不會(huì)變化的。
2.進(jìn)階版監(jiān)聽:
下面我們改變一下需求:基礎(chǔ)規(guī)則不變,但是因?yàn)楹笈_(tái)數(shù)據(jù)庫的更改(畫個(gè)圈圈咀咒他)我們需要提交一個(gè)這樣的數(shù)據(jù)結(jié)構(gòu)
data() {
return {
info: {
age: ""
},
infoMsg: ""
};
},
由于我們監(jiān)聽的是對(duì)象info中的屬性age值的變化,所以我們需要使用到的是深度監(jiān)聽,具體代碼如下:
<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 = "你還是個(gè)小孩";
} else if (val.age > 15 && val.age < 25) {
that.infoMsg = "你已經(jīng)是個(gè)少年";
} else {
that.infoMsg = "你已經(jīng)長大了";
}
},
deep: true
}
}
};
</script>
在這里需要注意的有兩點(diǎn):1,這里的function不能使用箭頭函數(shù)替代,如果使用箭頭函數(shù)的話,this的指向會(huì)是全局。2,你會(huì)注意到這里多加入一個(gè)屬性是deep,它的含義表示是否開啟深度監(jiān)聽,如果開啟值為true,反之為false。
3.最高級(jí)監(jiān)聽:
針對(duì)第二個(gè)案例不知道你有沒有發(fā)現(xiàn)一個(gè)問題:我們監(jiān)聽的是一個(gè)對(duì)象里面某個(gè)屬性的變化,但是如果當(dāng)這個(gè)對(duì)象里面有很多個(gè)值的時(shí)候,雖然也可以使用第二種方法進(jìn)行監(jiān)聽,但是這將會(huì)是對(duì)資源的一種極大的浪費(fèi),身為一個(gè)嚴(yán)謹(jǐn)?shù)某绦騿T(微笑臉),絕對(duì)不能允許這樣的事情發(fā)生,所以我們可以結(jié)合computed(計(jì)算屬性)對(duì)上面的代碼進(jìn)行優(yōu)化:
<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 = "你還是個(gè)小孩";
} else if (val > 15 && val < 25) {
that.infoMsg = "你已經(jīng)是個(gè)少年";
} else {
that.infoMsg = "你已經(jīng)長大了";
}
},
deep: true
}
}
};
</script>
通過上面的我們看出,這次我們監(jiān)聽的是計(jì)算屬性ageval,而計(jì)算屬性返回的則是info對(duì)象中age的值,與第二次的代碼進(jìn)行比較我們可以發(fā)現(xiàn)兩次代碼中監(jiān)聽的一個(gè)是對(duì)象info,一個(gè)是info對(duì)象中age的值,性能大大增強(qiáng),這就是我們期待的結(jié)果了。
總結(jié)
以上所述是小編給大家介紹的vue2.0監(jiān)聽屬性的使用心得及搭配計(jì)算屬性的使用,希望對(duì)大家有所幫助,如果大家有任何疑問請給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
相關(guān)文章
Vue2 監(jiān)聽屬性改變watch的實(shí)例代碼
今天小編就為大家分享一篇Vue2 監(jiān)聽屬性改變watch的實(shí)例代碼,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2018-08-08
Vue?處理異步加載順序問題之如何在Konva中確保文本在圖片之上顯示
在處理Konva中的異步加載順序問題時(shí),確保在圖像加載完成后再添加其他元素是關(guān)鍵,通過將回調(diào)函數(shù)放在imageObj.onload中,并正確處理變量捕獲,我們可以確保文本總是繪制在圖片之上,這不僅解決了顯示順序的問題,也為未來的調(diào)試提供了明確的方向,感興趣的朋友一起看看吧2024-07-07
解決vue運(yùn)行報(bào)錯(cuò)Error:Cannot?find?module?'@vue/cli-plugin-b
解決了因?yàn)榘姹締栴}在創(chuàng)建項(xiàng)目時(shí)出現(xiàn)的各種報(bào)錯(cuò)問題,這次在運(yùn)行時(shí)出現(xiàn)的問題,下面這篇文章主要給大家介紹了關(guān)于解決vue運(yùn)行報(bào)錯(cuò)Error:Cannot?find?module?'@vue/cli-plugin-babel'的相關(guān)資料,需要的朋友可以參考下2023-04-04
基于Vue3+TypeScript的全局對(duì)象的注入和使用詳解
這篇文章主要介紹了基于Vue3+TypeScript的全局對(duì)象的注入和使用,本篇隨筆主要介紹一下基于Vue3+TypeScript的全局對(duì)象的注入和使用,需要的朋友可以參考下2022-09-09

