vue監(jiān)聽(tīng)屬性watch的用法及使用場(chǎng)景詳解
1. 監(jiān)聽(tīng)屬性 watch
watch 是一個(gè)對(duì)象,鍵是需要觀察的表達(dá)式,用于觀察 Vue 實(shí)例上的一個(gè)表達(dá)式或者一個(gè)函數(shù)計(jì)算結(jié)果的變化。回調(diào)函數(shù)的參數(shù)是新值和舊值。值也可以是方法名,或者包含選項(xiàng)的對(duì)象。Vue 實(shí)例將會(huì)在實(shí)例化時(shí)調(diào)用 $watch(),遍歷 watch 對(duì)象的每一個(gè) property。
2. 常規(guī)用法
watch 監(jiān)聽(tīng)有兩個(gè)形參,第一個(gè)是新值,第二個(gè)是舊值。如下例子:使用 watch 監(jiān)聽(tīng)了 total 的值,當(dāng) total 的值改變時(shí),控制臺(tái)會(huì)打印出舊值和新值。
<template>
<div class="home_box">
<h1>{{ total }}</h1>
<button @click="handleAddTotal">增加</button>
</div>
</template>
<script>
export default {
name: 'Home',
watch: {
total(newValue, oldValue) {
console.log('舊值:', oldValue)
console.log('新值:', newValue)
}
},
data() {
return {
total: 0
}
},
methods: {
handleAddTotal() {
this.total++
}
}
}
</script>
3. 監(jiān)聽(tīng)對(duì)象和route變化
watch監(jiān)聽(tīng)的目標(biāo),可以是基本類(lèi)型,也可以是對(duì)象,也可以是對(duì)象里的一個(gè)值。而監(jiān)聽(tīng)目標(biāo)的屬性,可以是一個(gè)函數(shù),也可以是一個(gè)包含handler(回調(diào)函數(shù)),immediate(是否初始化后立即執(zhí)行一次)和deep(是否開(kāi)啟深度監(jiān)聽(tīng))的對(duì)象。
<script>
export default {
name: 'Home',
watch: {
// 監(jiān)聽(tīng)基本類(lèi)型
aaa(newValue, oldValue) {
console.log('舊值:', oldValue)
console.log('新值:', newValue)
},
// 監(jiān)聽(tīng)基本類(lèi)型,并且回調(diào)函數(shù)寫(xiě)在methods里,且初始化加載立即執(zhí)行一次
bbb: {
handler: 'handleBBB',
immediate: true
},
// 監(jiān)聽(tīng)對(duì)象類(lèi)型,需要開(kāi)啟深度監(jiān)聽(tīng)
ccc: {
handler: (newValue, oldValue) {
console.log('舊值:', oldValue)
console.log('新值:', newValue)
},
deep: true
},
// 監(jiān)聽(tīng)對(duì)象里的某個(gè)值
'ddd.d2.d21': {
handler: (newValue, oldValue) {
console.log('舊值:', oldValue)
console.log('新值:', newValue)
}
},
// 監(jiān)聽(tīng)route變化
'$route': {
handler: (newValue, oldValue) {
console.log('舊值:', oldValue)
console.log('新值:', newValue)
}
}
},
data() {
return {
aaa: 0,
bbb: 0,
ccc: {
c1: 0,
c2: 0
},
ddd: {
d1: 0,
d2: {
d21: 0
}
}
}
},
methods: {
handleBBB() {
this.bbb++
}
}
}
</script>
4. 使用場(chǎng)景
watch監(jiān)聽(tīng)屬性使用場(chǎng)景很多。比如:
- 即時(shí)表單驗(yàn)證
- 搜索
- 監(jiān)聽(tīng)數(shù)據(jù)變化,做出相應(yīng)改變
- …
如下例子,監(jiān)聽(tīng) keyword 的值,實(shí)時(shí)打印出來(lái)。
<template>
<div class="home_box">
<input type="text" v-model="keyword">
</div>
</template>
<script>
export default {
name: 'Home',
watch: {
keyword: {
handler: 'handleKeywordChange'
}
},
data() {
return {
keyword: '',
}
},
methods: {
handleKeywordChange(newValue, oldValue) {
console.log(newValue, oldValue)
}
}
}
</script>
附Watch 的高級(jí)用法
深度監(jiān)聽(tīng)數(shù)據(jù)的變化
在 Vue 中,深度監(jiān)聽(tīng)數(shù)據(jù)的變化意味著不僅監(jiān)聽(tīng)對(duì)象或數(shù)組本身的變化,還監(jiān)聽(tīng)它們內(nèi)部屬性或元素的變化。
當(dāng)將deep選項(xiàng)設(shè)置為true時(shí),Vue 會(huì)遞歸遍歷對(duì)象的所有屬性或數(shù)組的所有元素,并為每個(gè)屬性或元素都創(chuàng)建一個(gè)深度觀察者。這樣,無(wú)論是對(duì)象的某個(gè)屬性還是數(shù)組的某個(gè)元素發(fā)生變化,都能觸發(fā)相應(yīng)的回調(diào)函數(shù)。
使用深度監(jiān)聽(tīng)來(lái)監(jiān)聽(tīng)對(duì)象屬性的變化如下所示:
watch: {
'obj.foo': {
handler(newVal, oldVal) {
console.log('obj.foo屬性發(fā)生變化了,新值為:', newVal, '舊值為:', oldVal);
},
deep: true // 深度監(jiān)聽(tīng)
}
}
在上述示例中,obj是一個(gè)對(duì)象,foo是它的一個(gè)屬性。當(dāng)obj或foo發(fā)生變化時(shí),都能觸發(fā)深度觀察者的回調(diào)函數(shù)。
因此,通過(guò)在 Vue 的watch選項(xiàng)中將deep選項(xiàng)設(shè)置為true,可以實(shí)現(xiàn)對(duì)對(duì)象屬性或數(shù)組元素的深度監(jiān)聽(tīng),從而捕捉到它們內(nèi)部值的變化。
注意:深度監(jiān)聽(tīng)會(huì)帶來(lái)一些性能開(kāi)銷(xiāo),因?yàn)樗枰f歸遍歷對(duì)象或數(shù)組的所有屬性或元素。因此,只在需要深度監(jiān)聽(tīng)的情況下使用,以避免不必要的開(kāi)銷(xiāo)。
還需要特別注意的是,深度監(jiān)聽(tīng)僅適用于對(duì)象和數(shù)組,對(duì)于基本類(lèi)型的數(shù)據(jù)如字符串、數(shù)字等是不起作用的。
立即執(zhí)行 Watch 回調(diào)函數(shù)
在 Vue 中,watch 選項(xiàng)的回調(diào)函數(shù)默認(rèn)是在被監(jiān)聽(tīng)的數(shù)據(jù)發(fā)生變化后異步執(zhí)行的,即在下一次事件循環(huán)中執(zhí)行。
然而,有時(shí)我們可能需要立即響應(yīng)數(shù)據(jù)變化,并在變化發(fā)生后立即執(zhí)行回調(diào)函數(shù)。為了實(shí)現(xiàn)這一需求,Vue 提供了immediate選項(xiàng)。
當(dāng)在 watch 選項(xiàng)中設(shè)置immediate: true時(shí),Vue 會(huì)在監(jiān)聽(tīng)開(kāi)始之初立即執(zhí)行回調(diào)函數(shù),無(wú)論數(shù)據(jù)是否已經(jīng)發(fā)生變化。
使用immediate選項(xiàng)來(lái)實(shí)現(xiàn)立即執(zhí)行 watch 回調(diào)函數(shù)的效果如下所示:
watch: {
foo: {
handler(newVal, oldVal) {
console.log('foo屬性發(fā)生變化了,新值為:', newVal, '舊值為:', oldVal);
},
immediate: true // 立即執(zhí)行
}
}
在上述示例中,當(dāng) Vue 實(shí)例創(chuàng)建時(shí),會(huì)立即執(zhí)行一次foo屬性的 watch 回調(diào)函數(shù),無(wú)論foo的值是否已經(jīng)發(fā)生變化。隨后,如果foo發(fā)生變化,Vue 會(huì)在下一次事件循環(huán)中再次執(zhí)行 watch 回調(diào)函數(shù)。
總之,通過(guò)在 Vue 的 watch 選項(xiàng)中設(shè)置immediate: true,可以立即執(zhí)行 watch 回調(diào)函數(shù),不等待數(shù)據(jù)的真正變化。這在某些情況下可以用于立即響應(yīng)數(shù)據(jù)變化并執(zhí)行相關(guān)操作的需求。
注意:當(dāng)設(shè)置
immediate: true時(shí),回調(diào)函數(shù)會(huì)在監(jiān)聽(tīng)開(kāi)始時(shí)立即執(zhí)行一次,并且不會(huì)等待偵聽(tīng)的數(shù)據(jù)屬性的真正變化。這意味著你可能無(wú)法獲得先前的值,因?yàn)榇藭r(shí)回調(diào)函數(shù)仍然是在數(shù)據(jù)變化之前執(zhí)行的。
總結(jié)
到此這篇關(guān)于vue監(jiān)聽(tīng)屬性watch的用法及使用場(chǎng)景的文章就介紹到這了,更多相關(guān)vue監(jiān)聽(tīng)屬性watch內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- vue?watch監(jiān)聽(tīng)方法總結(jié)
- Vue使用watch監(jiān)聽(tīng)一個(gè)對(duì)象中的屬性的實(shí)現(xiàn)方法
- Vue使用watch監(jiān)聽(tīng)數(shù)組或?qū)ο?/a>
- Vue數(shù)據(jù)監(jiān)聽(tīng)方法watch的使用
- VUE3中watch監(jiān)聽(tīng)使用實(shí)例詳解
- vue中watch監(jiān)聽(tīng)器的觸發(fā)時(shí)機(jī)(watch的坑及解決)
- vue中watch如何同時(shí)監(jiān)聽(tīng)多個(gè)屬性
- vue中watch監(jiān)聽(tīng)不到變化的解決
- 詳解Vue3中Watch監(jiān)聽(tīng)事件的使用
相關(guān)文章
淺談VUE監(jiān)聽(tīng)窗口變化事件的問(wèn)題
下面小編就為大家分享一篇淺談VUE監(jiān)聽(tīng)窗口變化事件的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-02-02
Vue3中SetUp函數(shù)的參數(shù)props、context詳解
我們知道setup函數(shù)是組合API的核心入口函數(shù),下面這篇文章主要給大家介紹了關(guān)于Vue3中SetUp函數(shù)的參數(shù)props、context的相關(guān)資料,需要的朋友可以參考下2021-07-07
webpack vue 項(xiàng)目打包生成的文件,資源文件報(bào)404問(wèn)題的修復(fù)方法(總結(jié)篇)
這篇文章主要介紹了解決webpack vue 項(xiàng)目打包生成的文件,資源文件報(bào)404問(wèn)題的修復(fù)方法,需要的朋友可以參考下2018-01-01
Vue實(shí)現(xiàn)本地購(gòu)物車(chē)功能
這篇文章主要為大家詳細(xì)介紹了Vue實(shí)現(xiàn)本地購(gòu)物車(chē)功能,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-12-12
Vue3點(diǎn)擊側(cè)邊導(dǎo)航欄完成切換頁(yè)面內(nèi)組件全過(guò)程(WEB)
寫(xiě)頁(yè)面的時(shí)候都會(huì)用到一些導(dǎo)航欄、點(diǎn)擊不同的部分切換不同的頁(yè)面,下面這篇文章主要給大家介紹了關(guān)于Vue3點(diǎn)擊側(cè)邊導(dǎo)航欄完成切換頁(yè)面內(nèi)組件的相關(guān)資料,需要的朋友可以參考下2023-06-06

