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

淺談Vue3中watchEffect的具體用法

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

前言

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

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

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

watchEffect的副作用

什么是副作用(side effect),簡(jiǎn)單的說(shuō)副作用就是執(zhí)行某種操作,如對(duì)外部可變數(shù)據(jù)或變量的修改,外部接口的調(diào)用等。watchEffect的回調(diào)函數(shù)就是一個(gè)副作用函數(shù),因?yàn)槲覀兪褂?code>watchEffect就是偵聽到依賴的變化后執(zhí)行某些操作。

當(dāng)執(zhí)行副作用函數(shù)時(shí),它勢(shì)必會(huì)對(duì)系統(tǒng)帶來(lái)一些影響,如在副作用函數(shù)里執(zhí)行了一個(gè)定時(shí)器setInterval,因此我們必須處理副作用。 Vue3watchEffect偵聽副作用傳入的函數(shù)可以接收一個(gè) onInvalidate 函數(shù)作為入?yún)?,用?lái)注冊(cè)清理失效時(shí)的回調(diào)。當(dāng)以下情況發(fā)生時(shí),這個(gè)失效回調(diào)會(huì)被觸發(fā):

  • 副作用即將重新執(zhí)行時(shí)(即依賴的值改變)
  • 偵聽器被停止 (通過(guò)顯示調(diào)用返回值停止偵聽,或組件被卸載時(shí)隱式調(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)

上述代碼打印的順序?yàn)椋?0 -> 執(zhí)行了onInvalidate,最后執(zhí)行 -> 1

分析:初始化時(shí)先打印count的值0, 然后由于定時(shí)器把count的值更新為1, 此時(shí)副作用即將重新執(zhí)行,因此onInvalidate的回調(diào)函數(shù)會(huì)被觸發(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)

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

watchEffect的應(yīng)用

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

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

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

// 定時(shí)器注冊(cè)和銷毀
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))
  })
})

場(chǎng)景二:利用watchEffect作一個(gè)防抖節(jié)流(如取消請(qǐng)求)

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

......

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

相關(guān)閱讀

Vue3中watch的最佳實(shí)踐

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

相關(guān)文章

  • 傻瓜式vuex語(yǔ)法糖kiss-vuex整理

    傻瓜式vuex語(yǔ)法糖kiss-vuex整理

    kiss-vuex 是一個(gè)非常簡(jiǎn)單的語(yǔ)法糖類庫(kù),這篇文章主要介紹了傻瓜式vuex語(yǔ)法糖kiss-vuex整理,非常具有實(shí)用價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2018-12-12
  • vue集成高德地圖amap-jsapi-loader的實(shí)現(xiàn)

    vue集成高德地圖amap-jsapi-loader的實(shí)現(xiàn)

    本文主要介紹了vue集成高德地圖amap-jsapi-loader的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2023-06-06
  • 關(guān)于Element Loading的全局使用(自定義Loading)

    關(guān)于Element Loading的全局使用(自定義Loading)

    這篇文章主要介紹了關(guān)于Element Loading的全局使用(自定義Loading),具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-08-08
  • Vue過(guò)濾器filters的用法及時(shí)間戳轉(zhuǎn)換問(wèn)題

    Vue過(guò)濾器filters的用法及時(shí)間戳轉(zhuǎn)換問(wèn)題

    Vue的filters過(guò)濾器是比較常見的一個(gè)知識(shí)點(diǎn),下面我將結(jié)合時(shí)間戳轉(zhuǎn)換的例子帶你快速了解filters的用法,感興趣的朋友一起看看吧
    2021-09-09
  • element的表單校驗(yàn)證件號(hào)規(guī)則及輸入“無(wú)”的情況校驗(yàn)通過(guò)(示例代碼)

    element的表單校驗(yàn)證件號(hào)規(guī)則及輸入“無(wú)”的情況校驗(yàn)通過(guò)(示例代碼)

    這篇文章主要介紹了element的表單校驗(yàn)證件號(hào)規(guī)則及輸入“無(wú)”的情況校驗(yàn)通過(guò),使用方法對(duì)校驗(yàn)數(shù)據(jù)進(jìn)行過(guò)濾判斷,本文通過(guò)示例代碼給大家介紹的非常詳細(xì),感興趣的朋友一起看看吧
    2023-11-11
  • Vue.js?中的父子組件通信方式實(shí)例教程

    Vue.js?中的父子組件通信方式實(shí)例教程

    在 Vue.js 中,父子組件通信是非常重要的,在本文中,我們討論了 Vue.js 中父子組件通信的幾種方式,包括使用 props 傳遞數(shù)據(jù)、使用 Sync 修飾符實(shí)現(xiàn)雙向綁定、使用自定義事件傳遞數(shù)據(jù)、使用 $refs 訪問(wèn)子組件實(shí)例以及使用 $children 和 $parent 訪問(wèn)父子組件實(shí)例
    2023-09-09
  • vue3+vite+antd如何實(shí)現(xiàn)自定義主題

    vue3+vite+antd如何實(shí)現(xiàn)自定義主題

    這篇文章主要介紹了vue3+vite+antd如何實(shí)現(xiàn)自定義主題問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-03-03
  • Vue3 SFC 和 TSX 方式自定義組件實(shí)現(xiàn) v-model的詳細(xì)過(guò)程

    Vue3 SFC 和 TSX 方式自定義組件實(shí)現(xiàn) v-model的詳細(xì)

    v-model 是 vue3 中的一個(gè)內(nèi)置指令,很多表單元素都可以使用這個(gè)屬性,如 input、checkbox 等,咱可以在自定義組件中實(shí)現(xiàn) v-model,這篇文章主要介紹了Vue3 SFC 和 TSX 方式自定義組件實(shí)現(xiàn) v-model,需要的朋友可以參考下
    2022-10-10
  • vue中el-tree增加節(jié)點(diǎn)后如何重新刷新

    vue中el-tree增加節(jié)點(diǎn)后如何重新刷新

    這篇文章主要介紹了vue中el-tree增加節(jié)點(diǎn)后如何重新刷新,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-08-08
  • vue鍵盤事件keyup、keydown的作用

    vue鍵盤事件keyup、keydown的作用

    這篇文章主要介紹了vue鍵盤事件keyup、keydown的作用,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-12-12

最新評(píng)論