vue如何監(jiān)聽對象或者數組某個屬性的變化詳解
前言
在vue.js中監(jiān)聽某個屬性的改變,動態(tài)的去修改另外屬性的值,這是非常常見的業(yè)務場景。例如在一個購物車中,根據用戶添加的商品數量,動態(tài)修改頁面顯示的訂單總金額。要實現(xiàn)這樣的功能,主要有兩種方法可以實現(xiàn),一種是使用watch
監(jiān)聽,另外一種是使用computed
計算屬性。
用watch監(jiān)聽
在Vue組件中,可以使用watch
選項來監(jiān)聽數據的變化。假設你有一個data
中的屬性sourceProp
,當它變化時,你想修改另一個屬性targetProp
的值。
export default { data() { return { totalMoney: 0.00, buyCount: 1 }; }, watch: { buyCount(newValue, oldValue) { // 當buyCount變化時,修改totalMoney的值,這里的100是單個商品的金額 this.totalMoney = newValue * 100; } } };
1、watch
選項是一個對象,其中的鍵是要監(jiān)聽的數據屬性名(這里是buyCount
),值是一個函數。這個函數接收兩個參數,newValue
是屬性變化后的新值,oldValue
是變化前的值。
2、在函數內部,可以根據newValue
來修改其他屬性(這里將totalMoney
修改為newValue * 100
)。
深度監(jiān)聽
上述的方法,適合監(jiān)聽簡單的熟悉感,如果要監(jiān)聽的屬性是一個對象或者是一個數組,并且需要監(jiān)聽對象內部屬性的變化,要使用上述的方法就無法實現(xiàn)我們的需求。此時就需要使用深度監(jiān)聽。
export default { data() { return { goodsInfo: { price: 100.00, buyCount: 1 }, orderTotalMoney: 0.00 }; }, watch: { goodsInfo: { handler(newValue, oldValue) { this.orderTotalMoney = goodsInfo.buyCount * goodsInfo.price; }, deep: true// 開啟深度監(jiān)聽 } } };
深度監(jiān)聽會帶來一定的性能開銷,因為它會遞歸地檢查對象的每一個屬性。如果不需要監(jiān)聽對象內部的所有屬性變化,可以考慮使用淺拷貝等方式來手動比較對象的變化。
使用計算屬性
計算屬性可以根據其他數據屬性自動計算并返回一個新的值,并且會自動緩存結果。雖然它不是直接監(jiān)聽屬性變化,但可以達到類似的效果。
export default { data() { return { totalMoney: 0.00, buyCount: 1 }; }, computed: { totalMoney() { return this.totalMoney * 100; } } };
watch和計算屬性的區(qū)別
watch
主要用于在屬性變化時執(zhí)行一些副作用,比如異步操作、修改多個屬性等。計算屬性主要用于根據已有數據生成新的數據,并且具有緩存機制,只有當依賴的屬性發(fā)生變化時才會重新計算。
在Vue 3中使用watchEffect(組合式API)
在Vue 3的組合式API中,可以使用watchEffect
來實現(xiàn)屬性變化的監(jiān)聽。
import {ref, watchEffect} from 'vue'; export default { setup() { const totalMoney = ref(0); const buyCount = ref(0); watchEffect(() => { totalMoney.value = buyCount.value * 100; }); return { totalMoney: 0.00, buyCount: 1 }; } };
watchEffect
會立即執(zhí)行傳入的函數,并自動追蹤函數中使用的響應式數據(這里是buyCount
)。當這些響應式數據變化時,函數會再次執(zhí)行。這樣就可以根據buyCount
的變化動態(tài)修改totalMoney
的值。
在vue.js中監(jiān)聽某個屬性的改變,動態(tài)的去修改另外屬性的值,這是非常常見的業(yè)務場景。例如在一個購物車中,根據用戶添加的商品數量,動態(tài)修改頁面顯示的訂單總金額。要實現(xiàn)這樣的功能,主要有兩種方法可以實現(xiàn),一種是使用watch
監(jiān)聽,另外一種是使用computed
計算屬性。
用watch監(jiān)聽
在Vue組件中,可以使用watch
選項來監(jiān)聽數據的變化。假設你有一個data
中的屬性sourceProp
,當它變化時,你想修改另一個屬性targetProp
的值。
export default { data() { return { totalMoney: 0.00, buyCount: 1 }; }, watch: { buyCount(newValue, oldValue) { // 當buyCount變化時,修改totalMoney的值,這里的100是單個商品的金額 this.totalMoney = newValue * 100; } } };
1、watch
選項是一個對象,其中的鍵是要監(jiān)聽的數據屬性名(這里是buyCount
),值是一個函數。這個函數接收兩個參數,newValue
是屬性變化后的新值,oldValue
是變化前的值。
2、在函數內部,可以根據newValue
來修改其他屬性(這里將totalMoney
修改為newValue * 100
)。
深度監(jiān)聽
上述的方法,適合監(jiān)聽簡單的熟悉感,如果要監(jiān)聽的屬性是一個對象或者是一個數組,并且需要監(jiān)聽對象內部屬性的變化,要使用上述的方法就無法實現(xiàn)我們的需求。此時就需要使用深度監(jiān)聽。
export default { data() { return { goodsInfo: { price: 100.00, buyCount: 1 }, orderTotalMoney: 0.00 }; }, watch: { goodsInfo: { handler(newValue, oldValue) { this.orderTotalMoney = goodsInfo.buyCount * goodsInfo.price; }, deep: true// 開啟深度監(jiān)聽 } } };
深度監(jiān)聽會帶來一定的性能開銷,因為它會遞歸地檢查對象的每一個屬性。如果不需要監(jiān)聽對象內部的所有屬性變化,可以考慮使用淺拷貝等方式來手動比較對象的變化。
使用計算屬性
計算屬性可以根據其他數據屬性自動計算并返回一個新的值,并且會自動緩存結果。雖然它不是直接監(jiān)聽屬性變化,但可以達到類似的效果。
export default { data() { return { totalMoney: 0.00, buyCount: 1 }; }, computed: { totalMoney() { return this.totalMoney * 100; } } };
watch和計算屬性的區(qū)別
watch
主要用于在屬性變化時執(zhí)行一些副作用,比如異步操作、修改多個屬性等。計算屬性主要用于根據已有數據生成新的數據,并且具有緩存機制,只有當依賴的屬性發(fā)生變化時才會重新計算。
在Vue 3中使用watchEffect(組合式API)
在Vue 3的組合式API中,可以使用watchEffect
來實現(xiàn)屬性變化的監(jiān)聽。
import {ref, watchEffect} from 'vue'; export default { setup() { const totalMoney = ref(0); const buyCount = ref(0); watchEffect(() => { totalMoney.value = buyCount.value * 100; }); return { totalMoney: 0.00, buyCount: 1 }; } };
watchEffect
會立即執(zhí)行傳入的函數,并自動追蹤函數中使用的響應式數據(這里是buyCount
)。當這些響應式數據變化時,函數會再次執(zhí)行。這樣就可以根據buyCount
的變化動態(tài)修改totalMoney
的值。
總結
到此這篇關于vue如何監(jiān)聽對象或者數組某個屬性的變化的文章就介紹到這了,更多相關vue監(jiān)聽對象或者數組屬性變化內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
vue3 vue-draggable-next如何實現(xiàn)拖拽穿梭框效果
這篇文章主要介紹了vue3 vue-draggable-next如何實現(xiàn)拖拽穿梭框效果,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-06-06