欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

vue3中watch與watchEffect的區(qū)別

 更新時間:2023年02月17日 10:16:31   作者:Lvan的前端筆記  
vue3 新增的 Composition API中的 watchEffect 和 watch都可在 setup() 函數(shù)中使用,本文重點介紹vue3中watch與watchEffect的區(qū)別,感興趣的朋友一起看看吧

vue3中watch與watchEffect的區(qū)別

watch ref

const x = ref(0)
const y = ref(0)

// 單個 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}`)
  }
)

// 多個來源組成的數(shù)組
watch([x, () => y.value], ([newX, newY]) => {
  console.log(`x is ${newX} and y is ${newY}`)
})

watch reactive

// 提供一個 getter 函數(shù)
watch(
  () => obj.count,
  (count) => {
    console.log(`count is: ${count}`)
  },
  // 立即執(zhí)行
  { immediate: true }
)

注意,不要使用如下方式:

const obj = reactive({ count: 0 })

// 錯誤,因為 watch() 得到的參數(shù)是一個 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ā)

對比

watch 和 watchEffect 都能響應(yīng)式地執(zhí)行有副作用的回調(diào)。它們之間的主要區(qū)別是追蹤響應(yīng)式依賴的方式:

watch 只追蹤明確偵聽的數(shù)據(jù)源。它不會追蹤任何在回調(diào)中訪問到的東西。另外,僅在數(shù)據(jù)源確實改變時才會觸發(fā)回調(diào)。watch 會避免在發(fā)生副作用時追蹤依賴,因此,我們能更加精確地控制回調(diào)函數(shù)的觸發(fā)時機。

watchEffect,則會在副作用發(fā)生期間追蹤依賴。它會在同步執(zhí)行過程中,自動追蹤所有能訪問到的響應(yīng)式屬性。這更方便,而且代碼往往更簡潔,但有時其響應(yīng)性依賴關(guān)系會不那么明確。

一般的副作用就是說這個函數(shù)做了不屬于它應(yīng)該做的事,比如console.log,或者它修改了其他的外部變量之類的。
react中的函數(shù)組件要求必須是純函數(shù)也就是沒有副作用的函數(shù),就是因為這個函數(shù)會被很多次調(diào)用,如果有副作用比如修改了全局變量,那么將無法控制該變量的準確性。(react hooks 函數(shù)組件中的生命周期函數(shù)就是副作用)
vue里面一般就是說,一些當狀態(tài)改變時需要執(zhí)行的行為,比如在每次msg變量改變時我需要重新打印它,那么這個打印行為就可以說是一個副作用(effect)

擴展:vue3中的 watchEffect 和 watch 有什么區(qū)別以及如何使用

vue3 新增的 Composition API中的 watchEffect 和 watch
都可在 setup() 函數(shù)中使用

watchEffect:
1.它是立即執(zhí)行的,在頁面加載時會主動執(zhí)行一次,來收集依賴
2.不需要傳遞需要偵聽的內(nèi)容,它可以自動感知代碼依賴,只需要傳遞一個回調(diào)函數(shù)
3.它不能獲取之前數(shù)據(jù)的值
4.它的返回值用來停止此監(jiān)聽

例:

setup() {
  const { reactive, watchEffect } = vue;
  const data = reactive({ name:'lei' })

  const stop = watchEffect( () => {  // 返回值 stop 用來停止監(jiān)聽
    console.log( data.name )  // 頁面加載時執(zhí)行一次之后,當 data.name 改變時,將會再次執(zhí)行l(wèi)og

    setTimeout( () => {
      stop();  //5秒之后停止此監(jiān)聽
    }, 5000 )
  })
}

watch : (watch也可以在setup中使用)
1.具備一定的惰性 lazy ( 但可配置 immediate , 使其主動)
2.參數(shù)可拿到更改之前的值和更改之后的值
3.可以偵聽多個數(shù)據(jù)的變化,用一個偵聽器承載

例:

const { reactive, watch, ref } = vue;
const name = ref('yang')
// ref包裝過的可直接通過watch的第一個參數(shù)傳入
watch( name, (newValue,oldValue) => { //  第一個參數(shù) 需要監(jiān)聽的數(shù)據(jù)
  console.log(newValue)  // 新值
  console.log(newValue)  // 舊值
},{ immediate: true }) //  第三個參數(shù)可接受配置項

const data = reactive({ name:'lei', age:18 })
// 但是 reactive 包裝過的值不可以直接傳入,可使用箭頭函數(shù) return 出需要監(jiān)聽的數(shù)據(jù)
watch( () => data.name, (newValue,oldValue) => { //  第一個參數(shù) 需要監(jiān)聽的數(shù)據(jù)
  console.log(newValue)  // 新值
  console.log(newValue)  // 舊值
},{ immediate: true }) //  第三個參數(shù)可接受配置項

上邊說到可以偵聽多個數(shù)據(jù)的變化,用一個偵聽器承載,接著看

例:

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)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • vue自定義全局組件實現(xiàn)彈框案例

    vue自定義全局組件實現(xiàn)彈框案例

    這篇文章主要為大家詳細介紹了vue自定義全局組件實現(xiàn)彈框案例,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-03-03
  • Vue中的transition封裝組件的實現(xiàn)方法

    Vue中的transition封裝組件的實現(xiàn)方法

    這篇文章主要介紹了Vue中的transition封裝組件的實現(xiàn)方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-08-08
  • Vue通過WebSocket建立長連接的實現(xiàn)代碼

    Vue通過WebSocket建立長連接的實現(xiàn)代碼

    這篇文章主要介紹了Vue通過WebSocket建立長連接的實現(xiàn)代碼,文中給出了問題及解決方案,需要的朋友可以參考下
    2019-11-11
  • npm安裝vue腳手架報錯警告npm WARN deprecated

    npm安裝vue腳手架報錯警告npm WARN deprecated

    安裝vue腳手架報錯可能具體原因比較多,可以根據(jù)報錯信息進行排查,本文主要介紹了npm安裝vue腳手架報錯警告npm WARN deprecated,感興趣的可以了解一下
    2023-11-11
  • Vue 2.0雙向綁定原理的實現(xiàn)方法

    Vue 2.0雙向綁定原理的實現(xiàn)方法

    這篇文章主要為大家詳細介紹了Vue 2.0雙向綁定原理的實現(xiàn)方法,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-10-10
  • Vue?仿QQ左滑刪除組件功能

    Vue?仿QQ左滑刪除組件功能

    前幾天朋友在做vue項目開發(fā)時,有人反映?IOS?上面的滑動點擊有點問題,讓我們來幫忙解決,于是我就重寫了代碼,下面把vue仿qq左滑刪除組件功能分享到腳本之家平臺,需要的朋友參考下吧
    2018-03-03
  • vue實現(xiàn)的組件兄弟間通信功能示例

    vue實現(xiàn)的組件兄弟間通信功能示例

    這篇文章主要介紹了vue實現(xiàn)的組件兄弟間通信功能,結(jié)合實例形式分析了vue兄弟組件間通信的原理與相關(guān)操作技巧,需要的朋友可以參考下
    2018-12-12
  • elementUI select組件使用及注意事項詳解

    elementUI select組件使用及注意事項詳解

    這篇文章主要介紹了elementUI select組件使用及注意事項詳解,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2019-05-05
  • 項目中一鍵添加husky實現(xiàn)詳解

    項目中一鍵添加husky實現(xiàn)詳解

    這篇文章主要為大家介紹了項目中一鍵添加husky實現(xiàn)示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-09-09
  • vue使用better-scroll實現(xiàn)滑動以及左右聯(lián)動

    vue使用better-scroll實現(xiàn)滑動以及左右聯(lián)動

    這篇文章主要介紹了vue使用better-scroll實現(xiàn)滑動以及左右聯(lián)動,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-06-06

最新評論