Vue3監(jiān)聽屬性與Computed的區(qū)別詳解
一、引言
在 Vue 3 中,watch 和 computed 都是非常重要的概念,它們都可以用于觀察和響應(yīng)數(shù)據(jù)的變化,但在使用場(chǎng)景和原理上存在明顯的區(qū)別。本文將詳細(xì)解析 Vue 3 中監(jiān)聽屬性 (watch) 和計(jì)算屬性 (computed) 的區(qū)別,幫助你更好地理解它們的用法。
二、監(jiān)聽屬性 (watch)
watch
是 Vue 3 中用于觀察和響應(yīng)數(shù)據(jù)變化的機(jī)制之一。你可以使用 watch
來監(jiān)聽單個(gè)數(shù)據(jù)源的變化,并在數(shù)據(jù)變化時(shí)執(zhí)行相應(yīng)的回調(diào)函數(shù)。
1. 基本用法
import { ref, watch } from 'vue'; export default { setup() { const count = ref(0); watch(count, (newValue, oldValue) => { console.log(`Count changed from ${oldValue} to ${newValue}`); }); return { count }; } };
2. 監(jiān)聽多個(gè)屬性
import { reactive, watch } from 'vue'; export default { setup() { const state = reactive({ count: 23, name: 'Jiaranerzhi' }); watch( () => [state.count, state.name], ([newCount, newName], [oldCount, oldName]) => { console.log(`Count changed from ${oldCount} to ${newCount}`); console.log(`Name changed from ${oldName} to ${newName}`); } ); return { ...state }; } };
3. 深度監(jiān)聽
watch( state, (newValue, oldValue) => { // 當(dāng) state 中的任何屬性發(fā)生變化時(shí)觸發(fā) }, { deep: true } );
三、計(jì)算屬性 (computed)
computed
是 Vue 3 中另一種用于觀察和響應(yīng)數(shù)據(jù)變化的機(jī)制。與 watch
不同,computed
主要用于根據(jù)已有的數(shù)據(jù)進(jìn)行計(jì)算并返回一個(gè)新的值,這個(gè)新的值會(huì)被 Vue 緩存,只有當(dāng)依賴的數(shù)據(jù)發(fā)生變化時(shí)才會(huì)重新計(jì)算。
1. 基本用法
import { ref, computed } from 'vue'; export default { setup() { const firstName = ref('Alen'); const lastName = ref('Jia'); const fullName = computed(() => { return `${firstName.value} ${lastName.value}`; }); return { firstName, lastName, fullName }; } };
2. 監(jiān)聽多個(gè)屬性
computed
會(huì)自動(dòng)追蹤其依賴的數(shù)據(jù),并根據(jù)這些數(shù)據(jù)的變化重新計(jì)算。因此,你可以很方便地在 computed
函數(shù)中使用多個(gè)數(shù)據(jù)屬性。
3. 緩存機(jī)制
computed
的一個(gè)重要特點(diǎn)是它的緩存機(jī)制。只有當(dāng)其依賴的數(shù)據(jù)發(fā)生變化時(shí),computed
屬性才會(huì)重新計(jì)算。這可以提高性能,特別是在進(jìn)行復(fù)雜計(jì)算或需要頻繁訪問計(jì)算屬性時(shí)。
四、區(qū)別總結(jié)
- 用途:
watch
主要用于觀察和響應(yīng)數(shù)據(jù)的變化并執(zhí)行相應(yīng)的操作,而computed
主要用于根據(jù)已有的數(shù)據(jù)進(jìn)行計(jì)算并返回一個(gè)新的值。 - 觸發(fā)時(shí)機(jī):
watch
是在數(shù)據(jù)變化時(shí)觸發(fā)回調(diào)函數(shù),而computed
是在訪問其值時(shí)進(jìn)行計(jì)算(如果依賴的數(shù)據(jù)發(fā)生變化)。 - 緩存:
computed
具有緩存機(jī)制,只有當(dāng)依賴的數(shù)據(jù)發(fā)生變化時(shí)才會(huì)重新計(jì)算,而watch
沒有緩存機(jī)制。 - 性能:對(duì)于需要頻繁訪問的計(jì)算屬性,
computed
通常比watch
更高效,因?yàn)樗梢员苊獠槐匾闹貜?fù)計(jì)算。
五、結(jié)語
在 Vue 3 中,watch
和 computed
都是非常重要的工具,它們可以幫助你更好地觀察和響應(yīng)數(shù)據(jù)的變化。選擇使用哪種機(jī)制取決于你的具體需求和場(chǎng)景。希望本文能夠幫助你更好地理解和使用 Vue 3 中的 watch
和 computed
的區(qū)別。
以上就是Vue3監(jiān)聽屬性與Computed的區(qū)別詳解的詳細(xì)內(nèi)容,更多關(guān)于Vue3監(jiān)聽屬性與Computed區(qū)別的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
Vue3+Vite實(shí)現(xiàn)項(xiàng)目搭建步驟
這篇文章主要介紹了Vue3+Vite實(shí)現(xiàn)項(xiàng)目搭建步驟,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-07-07vue使用better-scroll實(shí)現(xiàn)滑動(dòng)以及左右聯(lián)動(dòng)
這篇文章主要介紹了vue使用better-scroll實(shí)現(xiàn)滑動(dòng)以及左右聯(lián)動(dòng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-06-06用vue2.0實(shí)現(xiàn)點(diǎn)擊選中active其他選項(xiàng)互斥的效果
這篇文章主要介紹了用vue2.0實(shí)現(xiàn)點(diǎn)擊選中active其他選項(xiàng)互斥的效果,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-04-04Vue實(shí)現(xiàn)數(shù)據(jù)導(dǎo)入的四種方法(resource、Axios、Fetch、Excel導(dǎo)入)
本文主要介紹了Vue實(shí)現(xiàn)數(shù)據(jù)導(dǎo)入的四種方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-07-07vue使用js-audio-recorder實(shí)現(xiàn)錄音功能
這篇文章主要為大家詳細(xì)介紹了vue如何使用js-audio-recorder實(shí)現(xiàn)錄音功能,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2023-12-12vue?watch報(bào)錯(cuò):Error?in?callback?for?watcher?"xxx&qu
這篇文章主要給大家介紹了關(guān)于vue?watch報(bào)錯(cuò):Error?in?callback?for?watcher?“xxx“:“TypeError:Cannot?read?properties?of?undefined的解決方法,需要的朋友可以參考下2023-03-03