vue3中watch與watchEffect的區(qū)別
vue3中watch與watchEffect的區(qū)別
watch ref
const x = ref(0)
const y = ref(0)
// 單個(gè) ref
watch(x, (newX) => {
console.log(`x is ${newX}`)
})
// getter 函數(shù)
watch(
() => x.value + y.value,
(sum) => {
console.log(`sum of x + y is: ${sum}`)
}
)
// 多個(gè)來(lái)源組成的數(shù)組
watch([x, () => y.value], ([newX, newY]) => {
console.log(`x is ${newX} and y is ${newY}`)
})watch reactive
// 提供一個(gè) getter 函數(shù)
watch(
() => obj.count,
(count) => {
console.log(`count is: ${count}`)
},
// 立即執(zhí)行
{ immediate: true }
)注意,不要使用如下方式:
const obj = reactive({ count: 0 })
// 錯(cuò)誤,因?yàn)?watch() 得到的參數(shù)是一個(gè) number
watch(obj.count, (count) => {
console.log(`count is: ${count}`)
})watchEffect
不用顯式的定義要 watch 的參數(shù)
const todoId = ref(0)
watchEffect(async () => {
const response = await fetch(
`https://jsonplaceholder.typicode.com/todos/${todoId.value}`
)
data.value = await response.json()
})todoId 的值改變了才觸發(fā)
對(duì)比
watch 和 watchEffect 都能響應(yīng)式地執(zhí)行有副作用的回調(diào)。它們之間的主要區(qū)別是追蹤響應(yīng)式依賴(lài)的方式:
watch 只追蹤明確偵聽(tīng)的數(shù)據(jù)源。它不會(huì)追蹤任何在回調(diào)中訪問(wèn)到的東西。另外,僅在數(shù)據(jù)源確實(shí)改變時(shí)才會(huì)觸發(fā)回調(diào)。watch 會(huì)避免在發(fā)生副作用時(shí)追蹤依賴(lài),因此,我們能更加精確地控制回調(diào)函數(shù)的觸發(fā)時(shí)機(jī)。
watchEffect,則會(huì)在副作用發(fā)生期間追蹤依賴(lài)。它會(huì)在同步執(zhí)行過(guò)程中,自動(dòng)追蹤所有能訪問(wèn)到的響應(yīng)式屬性。這更方便,而且代碼往往更簡(jiǎn)潔,但有時(shí)其響應(yīng)性依賴(lài)關(guān)系會(huì)不那么明確。
一般的副作用就是說(shuō)這個(gè)函數(shù)做了不屬于它應(yīng)該做的事,比如console.log,或者它修改了其他的外部變量之類(lèi)的。
react中的函數(shù)組件要求必須是純函數(shù)也就是沒(méi)有副作用的函數(shù),就是因?yàn)檫@個(gè)函數(shù)會(huì)被很多次調(diào)用,如果有副作用比如修改了全局變量,那么將無(wú)法控制該變量的準(zhǔn)確性。(react hooks 函數(shù)組件中的生命周期函數(shù)就是副作用)
vue里面一般就是說(shuō),一些當(dāng)狀態(tài)改變時(shí)需要執(zhí)行的行為,比如在每次msg變量改變時(shí)我需要重新打印它,那么這個(gè)打印行為就可以說(shuō)是一個(gè)副作用(effect)
擴(kuò)展:vue3中的 watchEffect 和 watch 有什么區(qū)別以及如何使用
vue3 新增的 Composition API中的 watchEffect 和 watch
都可在 setup() 函數(shù)中使用
watchEffect:
1.它是立即執(zhí)行的,在頁(yè)面加載時(shí)會(huì)主動(dòng)執(zhí)行一次,來(lái)收集依賴(lài)
2.不需要傳遞需要偵聽(tīng)的內(nèi)容,它可以自動(dòng)感知代碼依賴(lài),只需要傳遞一個(gè)回調(diào)函數(shù)
3.它不能獲取之前數(shù)據(jù)的值
4.它的返回值用來(lái)停止此監(jiān)聽(tīng)
例:
setup() {
const { reactive, watchEffect } = vue;
const data = reactive({ name:'lei' })
const stop = watchEffect( () => { // 返回值 stop 用來(lái)停止監(jiān)聽(tīng)
console.log( data.name ) // 頁(yè)面加載時(shí)執(zhí)行一次之后,當(dāng) data.name 改變時(shí),將會(huì)再次執(zhí)行l(wèi)og
setTimeout( () => {
stop(); //5秒之后停止此監(jiān)聽(tīng)
}, 5000 )
})
}watch : (watch也可以在setup中使用)
1.具備一定的惰性 lazy ( 但可配置 immediate , 使其主動(dòng))
2.參數(shù)可拿到更改之前的值和更改之后的值
3.可以偵聽(tīng)多個(gè)數(shù)據(jù)的變化,用一個(gè)偵聽(tīng)器承載
例:
const { reactive, watch, ref } = vue;
const name = ref('yang')
// ref包裝過(guò)的可直接通過(guò)watch的第一個(gè)參數(shù)傳入
watch( name, (newValue,oldValue) => { // 第一個(gè)參數(shù) 需要監(jiān)聽(tīng)的數(shù)據(jù)
console.log(newValue) // 新值
console.log(newValue) // 舊值
},{ immediate: true }) // 第三個(gè)參數(shù)可接受配置項(xiàng)
const data = reactive({ name:'lei', age:18 })
// 但是 reactive 包裝過(guò)的值不可以直接傳入,可使用箭頭函數(shù) return 出需要監(jiān)聽(tīng)的數(shù)據(jù)
watch( () => data.name, (newValue,oldValue) => { // 第一個(gè)參數(shù) 需要監(jiān)聽(tīng)的數(shù)據(jù)
console.log(newValue) // 新值
console.log(newValue) // 舊值
},{ immediate: true }) // 第三個(gè)參數(shù)可接受配置項(xiàng)上邊說(shuō)到可以偵聽(tīng)多個(gè)數(shù)據(jù)的變化,用一個(gè)偵聽(tīng)器承載,接著看
例:
const data = reactive({ name:'lei', age:18 })
// 可用數(shù)組接收參數(shù)
watch( [() => data.name, () => data.age], ([newName, newAge], [oldName, oldAge]) => {
console.log(newName, newAge) // 新值
console.log(oldName, oldAge) // 舊值
}) 具體需要用 watch 還是 watchEffect 就看業(yè)務(wù)需求啦
到此這篇關(guān)于vue3中watch與watchEffect的區(qū)別的文章就介紹到這了,更多相關(guān)vue3 watch與watchEffect的區(qū)別內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- 詳解Vue3?中的watchEffect?特性
- vue3數(shù)據(jù)監(jiān)聽(tīng)watch/watchEffect的示例代碼
- vue3中watch和watchEffect實(shí)戰(zhàn)梳理
- Vue3中的?computed,watch,watchEffect的使用方法
- Vue3?中?watch?與?watchEffect?區(qū)別及用法小結(jié)
- vue3中的watch和watchEffect實(shí)例詳解
- 淺談Vue3中watchEffect的具體用法
- vue3的watch和watchEffect你了解嗎
- VUE3中watch和watchEffect的用法詳解
- Vue3中watchEffect的用途淺析
- vue3中watch和watchEffect的區(qū)別
相關(guān)文章
Vue中的transition封裝組件的實(shí)現(xiàn)方法
這篇文章主要介紹了Vue中的transition封裝組件的實(shí)現(xiàn)方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-08-08
Vue通過(guò)WebSocket建立長(zhǎng)連接的實(shí)現(xiàn)代碼
這篇文章主要介紹了Vue通過(guò)WebSocket建立長(zhǎng)連接的實(shí)現(xiàn)代碼,文中給出了問(wèn)題及解決方案,需要的朋友可以參考下2019-11-11
npm安裝vue腳手架報(bào)錯(cuò)警告npm WARN deprecated
安裝vue腳手架報(bào)錯(cuò)可能具體原因比較多,可以根據(jù)報(bào)錯(cuò)信息進(jìn)行排查,本文主要介紹了npm安裝vue腳手架報(bào)錯(cuò)警告npm WARN deprecated,感興趣的可以了解一下2023-11-11
elementUI select組件使用及注意事項(xiàng)詳解
這篇文章主要介紹了elementUI select組件使用及注意事項(xiàng)詳解,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2019-05-05
項(xiàng)目中一鍵添加husky實(shí)現(xiàn)詳解
這篇文章主要為大家介紹了項(xiàng)目中一鍵添加husky實(shí)現(xiàn)示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-09-09
vue使用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

