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

淺談Vue3中watchEffect的具體用法

 更新時間:2022年05月03日 09:06:05   作者:HexOr  
watchEffect,它立即執(zhí)行傳入的一個函數(shù),同時響應式追蹤其依賴,并在其依賴變更時重新運行該函數(shù),本文主要介紹了Vue3中watchEffect的具體用法,感興趣的可以了解一下

前言

watchEffect,它立即執(zhí)行傳入的一個函數(shù),同時響應式追蹤其依賴,并在其依賴變更時重新運行該函數(shù)。

換句話說:watchEffect相當于將watch 的依賴源和回調(diào)函數(shù)合并,當任何你有用到的響應式依賴更新時,該回調(diào)函數(shù)便會重新執(zhí)行。不同于 watch,watchEffect 的回調(diào)函數(shù)會被立即執(zhí)行(即 { immediate: true }

此文主要講述怎樣利用清除副作用使我們的代碼更加優(yōu)雅~

watchEffect的副作用

什么是副作用(side effect),簡單的說副作用就是執(zhí)行某種操作,如對外部可變數(shù)據(jù)或變量的修改,外部接口的調(diào)用等。watchEffect的回調(diào)函數(shù)就是一個副作用函數(shù),因為我們使用watchEffect就是偵聽到依賴的變化后執(zhí)行某些操作。

當執(zhí)行副作用函數(shù)時,它勢必會對系統(tǒng)帶來一些影響,如在副作用函數(shù)里執(zhí)行了一個定時器setInterval,因此我們必須處理副作用。 Vue3watchEffect偵聽副作用傳入的函數(shù)可以接收一個 onInvalidate 函數(shù)作為入?yún)ⅲ脕碜郧謇硎r的回調(diào)。當以下情況發(fā)生時,這個失效回調(diào)會被觸發(fā):

  • 副作用即將重新執(zhí)行時(即依賴的值改變)
  • 偵聽器被停止 (通過顯示調(diào)用返回值停止偵聽,或組件被卸載時隱式調(diào)用了停止偵聽)
import { watchEffect, ref } from 'vue'

const count = ref(0)
watchEffect((onInvalidate) => {
  console.log(count.value)
  onInvalidate(() => {
    console.log('執(zhí)行了onInvalidate')
  })
})

setTimeout(()=> {
  count.value++
}, 1000)

上述代碼打印的順序為: 0 -> 執(zhí)行了onInvalidate,最后執(zhí)行 -> 1

分析:初始化時先打印count的值0, 然后由于定時器把count的值更新為1, 此時副作用即將重新執(zhí)行,因此onInvalidate的回調(diào)函數(shù)會被觸發(fā),打印執(zhí)行了onInvalidate,然后執(zhí)行了副作用函數(shù),打印count的值1。

import { watchEffect, ref } from 'vue'

const count = ref(0)
const stop = watchEffect((onInvalidate) => {
  console.log(count.value)
  onInvalidate(() => {
    console.log('執(zhí)行了onInvalidate')
  })
})

setTimeout(()=> {
  stop()
}, 1000)

上述代碼:當我們顯示執(zhí)行stop函數(shù)停止偵聽,此時也會觸發(fā)onInvalidate的回調(diào)函數(shù)。同樣,watchEffect所在的組件被卸載時會隱式調(diào)用stop函數(shù)停止偵聽,故也能觸發(fā)onInvalidate的回調(diào)函數(shù)。

watchEffect的應用

利用watchEffect的非惰性執(zhí)行,以及傳入的onInvalidate 函數(shù),我們可以做什么事情了?

場景一:平時我們定義一個定時器,或者監(jiān)聽某個事件,我們需要在mounted生命周期鉤子函數(shù)內(nèi)定義或者注冊,然后組件銷毀之前在beforeUnmount鉤子函數(shù)里清除定時器或取消監(jiān)聽。這樣做我們的邏輯被分散在兩個生命周期,不利于維護和閱讀。

如果我利用watchEffect,創(chuàng)造和銷毀邏輯放在了一起,此時代碼更加優(yōu)雅易讀~

// 定時器注冊和銷毀
watchEffect((onInvalidate) => {
  const timer = setInterval(()=> {
    // ...
  }, 1000)
  onInvalidate(() => clearInterval(timer))
})

const handleClick = () => {
 // ...
}
// dom的監(jiān)聽和取消監(jiān)聽
onMounted(()=>{
  watchEffect((onInvalidate) => {
    document.querySelector('.btn').addEventListener('click', handleClick, false)
    onInvalidate(() => document.querySelector('.btn').removeEventListener('click', handleClick))
  })
})

場景二:利用watchEffect作一個防抖節(jié)流(如取消請求)

const id = ref(13)
watchEffect(onInvalidate => {
   // 異步請求
  const token = performAsyncOperation(id.value)
  // 如果id頻繁改變,會觸發(fā)失效函數(shù),取消之前的接口請求
  onInvalidate(() => {
    // id has changed or watcher is stopped.
    // invalidate previously pending async operation
    token.cancel()
  })
})

......

當然watchEffect還能做很多事情,比如打開一個修改的modal彈窗,如果檢測到id變化,我們可以在onInvalidate函數(shù)內(nèi),重置初始參數(shù)...這里只是一個拋磚引玉的作用,望大家多多發(fā)掘~

相關(guān)閱讀

Vue3中watch的最佳實踐

到此這篇關(guān)于淺談Vue3中watchEffect的具體用法的文章就介紹到這了,更多相關(guān)Vue3 watchEffect內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • VUE 項目在IE11白屏報錯 SCRIPT1002: 語法錯誤的解決

    VUE 項目在IE11白屏報錯 SCRIPT1002: 語法錯誤的解決

    這篇文章主要介紹了VUE 項目在IE11白屏報錯 SCRIPT1002: 語法錯誤的解決,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-09-09
  • vue中forEach循環(huán)的使用講解

    vue中forEach循環(huán)的使用講解

    這篇文章主要介紹了vue中forEach循環(huán)的使用,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-06-06
  • vue3實現(xiàn)旋轉(zhuǎn)圖片驗證

    vue3實現(xiàn)旋轉(zhuǎn)圖片驗證

    這篇文章主要為大家詳細介紹了vue3實現(xiàn)旋轉(zhuǎn)圖片驗證,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-04-04
  • vue-cli項目中使用Mockjs詳解

    vue-cli項目中使用Mockjs詳解

    這篇文章主要介紹了vue-cli項目中使用Mockjs詳解,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-05-05
  • element表格組件實現(xiàn)右鍵菜單的功能

    element表格組件實現(xiàn)右鍵菜單的功能

    本文主要介紹了element表格組件實現(xiàn)右鍵菜單的功能,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-03-03
  • Vue自定義過濾器格式化數(shù)字三位加一逗號實現(xiàn)代碼

    Vue自定義過濾器格式化數(shù)字三位加一逗號實現(xiàn)代碼

    這篇文章主要介紹了Vue自定義過濾器格式化數(shù)字三位加一逗號的實現(xiàn)代碼,需要的朋友可以參考下
    2018-03-03
  • vuex如何重置所有state(可定制)

    vuex如何重置所有state(可定制)

    在正式場景中我們經(jīng)常遇到一個問題,就是登出頁面或其他操作的時候,我們需要重置所有的vuex,讓其變?yōu)槌跏紶顟B(tài),那么如何重置呢,下面就跟隨小編一起來了解一下
    2019-01-01
  • VSCode使用之Vue工程配置eslint

    VSCode使用之Vue工程配置eslint

    這篇文章主要介紹了VSCode使用之Vue工程配置eslint,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2019-04-04
  • vue車牌搜索組件使用方法詳解

    vue車牌搜索組件使用方法詳解

    這篇文章主要為大家詳細介紹了vue車牌搜索組件的使用方法,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-09-09
  • 淺談在Vue-cli里基于axios封裝復用請求

    淺談在Vue-cli里基于axios封裝復用請求

    這篇文章主要介紹了淺談在Vue-cli里基于axios封裝復用請求,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-11-11

最新評論