Vue監(jiān)聽屬性圖文實(shí)例詳解
?什么是監(jiān)聽屬性?
??所謂監(jiān)聽就是對(duì)內(nèi)置對(duì)象的狀態(tài)或者屬性變化進(jìn)行監(jiān)聽并且做出反應(yīng)的響應(yīng),監(jiān)聽屬性,意思就是可以監(jiān)視其他數(shù)據(jù)的變化。
監(jiān)聽屬性和計(jì)算屬性的區(qū)別?
計(jì)算屬性是依賴的值改變后重新計(jì)算結(jié)果更新DOM,會(huì)進(jìn)行緩存。
屬性監(jiān)聽的是屬性值,當(dāng)定義的值發(fā)生變化時(shí),執(zhí)行相對(duì)應(yīng)的函數(shù)。
最主要的用途區(qū)別:
計(jì)算屬性不能執(zhí)行異步任務(wù)。計(jì)算屬性一般不會(huì)用來向服務(wù)器請(qǐng)求或者執(zhí)行異步任務(wù),因?yàn)楹臅r(shí)可能會(huì)比較長(zhǎng),我們的計(jì)算屬性要實(shí)時(shí)更新。所以這個(gè)異步任務(wù)就可以用監(jiān)聽屬性來做。
總之一句話:computed能實(shí)現(xiàn)的,watch都能實(shí)現(xiàn),computed不能實(shí)現(xiàn)的,watch也能實(shí)現(xiàn)
監(jiān)聽屬性的使用
使用watch配置項(xiàng),在配置項(xiàng)里面寫上要監(jiān)視的屬性,每次屬性值的變化都會(huì)觸發(fā)handler函數(shù)回調(diào),也可以監(jiān)視計(jì)算屬性的變化。

例子:
監(jiān)視輸入框的變化

代碼
<template>
<div class="main">
我:<el-input v-model="name" placeholder="請(qǐng)輸入名字"></el-input>
好友1<el-input v-model="friends.friend_1" placeholder="請(qǐng)輸入名字"></el-input>
好友2<el-input v-model="friends.friend_2" placeholder="請(qǐng)輸入名字"></el-input>
</div>
</template>
<script>
export default {
data(){
return{
name:'浪漫主義碼農(nóng)',
friends:{friend_1:'張三',friend_2:'李四'}
}
},
watch:{
name:{
handler(newValue,oldValue){ //newValue 新的值,oldValue變化前的值
console.log(newValue,oldValue)
this.friends.friend_1='王五'
}
},
//監(jiān)視多級(jí)結(jié)構(gòu)中某個(gè)屬性的變化
'friends.friend_1':{
handler(newValue,oldValue){
console.log(newValue,oldValue)
}
},
'friends.friend_2':{
handler(newValue,oldValue){
console.log(newValue,oldValue)
}
},
}
};
</script>
深度監(jiān)聽
當(dāng)我們的對(duì)象有多層結(jié)構(gòu)的時(shí)候,我們要監(jiān)聽的對(duì)象的屬性很多,避免一個(gè)一個(gè)屬性單獨(dú)寫,這個(gè)時(shí)候用到深度監(jiān)聽。
在watch配置中,監(jiān)視屬性對(duì)象中,配置deep 設(shè)置為 true 用于監(jiān)聽多級(jí)對(duì)象或者數(shù)組內(nèi)部值的變化
watch:{
//監(jiān)視多級(jí)結(jié)構(gòu)中所有屬性的變化
friends:{
handler(newValue,oldValue){
console.log(newValue,oldValue,"aa")
},
deep:true, //開啟深度監(jiān)聽
}
}

注意:這里有個(gè)問題,深度監(jiān)聽時(shí)會(huì)出現(xiàn)新舊值相同的現(xiàn)象?
原因:
官方的解釋:
在變異(不是替換)對(duì)象或數(shù)組時(shí),舊值將與新值相同,因?yàn)樗鼈兊囊弥赶蛲粋€(gè)對(duì)象/數(shù)組。Vue不會(huì)保留變異之前值的副本
就是導(dǎo)致了指針的變化。在我的js深拷貝你還不會(huì)嗎 文章里講到數(shù)據(jù)的存儲(chǔ)
立即調(diào)用
和deep配置的地方一樣。
immediate 設(shè)置為 true 將立即以觸發(fā)當(dāng)前handler回調(diào)
watch:{
name:{
handler(newValue,oldValue){ //newValue 新的值,oldValue變化前的值
console.log(newValue,oldValue)
this.friends.friend_1='王五'
},
immediate:true
},
}
在頁(yè)面加載的時(shí)候就執(zhí)行了一次,所以舊數(shù)據(jù)為undefined

寫在最后
watch監(jiān)聽屬性通??梢杂迷?數(shù)據(jù)持久化、派發(fā)事件并同步/異步執(zhí)行,驗(yàn)證格式...
到此這篇關(guān)于Vue監(jiān)聽屬性的文章就介紹到這了,更多相關(guān)Vue監(jiān)聽屬性內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
關(guān)于SpringBoot與Vue交互跨域問題解決方案
最近在利用springboot+vue整合開發(fā)一個(gè)前后端分離的個(gè)人博客網(wǎng)站,所以這一篇總結(jié)一下在開發(fā)中遇到的一個(gè)問題,關(guān)于解決在使用vue和springboot在開發(fā)前后端分離的項(xiàng)目時(shí),如何解決跨域問題。在這里分別分享兩種方法,分別在前端vue中解決和在后臺(tái)springboot中解決。2021-10-10
詳解VueJS 數(shù)據(jù)驅(qū)動(dòng)和依賴追蹤分析
這篇文章主要介紹了詳解VueJS 數(shù)據(jù)驅(qū)動(dòng)和依賴追蹤分析,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-07-07
vue實(shí)現(xiàn)給當(dāng)前元素添加樣式,其他元素?zé)o樣式問題
這篇文章主要介紹了vue實(shí)現(xiàn)給當(dāng)前元素添加樣式,其他元素?zé)o樣式問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-05-05
vue3項(xiàng)目+element-plus:時(shí)間選擇器格式化方式
這篇文章主要介紹了vue3項(xiàng)目+element-plus:時(shí)間選擇器格式化方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-03-03
詳解Vue3頁(yè)面如何自適應(yīng)表格滾動(dòng)高度
這篇文章主要為大家詳細(xì)介紹了Vue3頁(yè)面如何自適應(yīng)表格滾動(dòng)高度,文中的示例代碼講解詳細(xì),具有一定的借鑒價(jià)值,感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2024-02-02
深入探究Vue2響應(yīng)式原理的實(shí)現(xiàn)及存在的缺陷
Vue的響應(yīng)式數(shù)據(jù)機(jī)制是其核心特性之一,它能夠自動(dòng)追蹤數(shù)據(jù)的變化,并實(shí)時(shí)更新相關(guān)的視圖,然而,Vue2中的響應(yīng)式數(shù)據(jù)機(jī)制并非完美無缺,本文將探討Vue2響應(yīng)式原理及其存在的缺陷2023-08-08
vue實(shí)現(xiàn)點(diǎn)擊圖片放大效果
這篇文章主要為大家詳細(xì)介紹了vue實(shí)現(xiàn)點(diǎn)擊圖片放大效果,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-08-08
vue?element-plus圖片預(yù)覽實(shí)現(xiàn)方法
這篇文章主要給大家介紹了關(guān)于vue?element-plus圖片預(yù)覽實(shí)現(xiàn)的相關(guān)資料,最近的項(xiàng)目中有圖片預(yù)覽的場(chǎng)景,也是踩了一些坑,在這里總結(jié)一下,需要的朋友可以參考下2023-07-07

