91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Vue3中的watchEffect怎么用

發布時間:2022-05-05 10:07:39 來源:億速云 閱讀:267 作者:iii 欄目:開發技術

本篇內容主要講解“Vue3中的watchEffect怎么用”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“Vue3中的watchEffect怎么用”吧!

前言

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

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

watchEffect的副作用

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

當執行副作用函數時,它勢必會對系統帶來一些影響,如在副作用函數里執行了一個定時器setInterval,因此我們必須處理副作用。 Vue3watchEffect偵聽副作用傳入的函數可以接收一個 onInvalidate 函數作為入參,用來注冊清理失效時的回調。當以下情況發生時,這個失效回調會被觸發:

  • 副作用即將重新執行時(即依賴的值改變)

  • 偵聽器被停止 (通過顯示調用返回值停止偵聽,或組件被卸載時隱式調用了停止偵聽)

import { watchEffect, ref } from 'vue'

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

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

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

分析:初始化時先打印count的值0, 然后由于定時器把count的值更新為1, 此時副作用即將重新執行,因此onInvalidate的回調函數會被觸發,打印執行了onInvalidate,然后執行了副作用函數,打印count的值1

import { watchEffect, ref } from 'vue'

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

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

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

watchEffect的應用

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

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

如果我利用watchEffect,創造和銷毀邏輯放在了一起,此時代碼更加優雅易讀~

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

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

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

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

到此,相信大家對“Vue3中的watchEffect怎么用”有了更深的了解,不妨來實際操作一番吧!這里是億速云網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續學習!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

广德县| 万宁市| 东光县| 永昌县| 阳山县| 醴陵市| 工布江达县| 彝良县| 赤壁市| 阜城县| 宜章县| 门源| 杭锦旗| 尼木县| 呼伦贝尔市| 明星| 辉县市| 来凤县| 上栗县| 鹤山市| 巴楚县| 镇沅| 福海县| 库尔勒市| 互助| 巴林右旗| 汉川市| 南丹县| 仁化县| 新民市| 隆子县| 黎川县| 新闻| 井冈山市| 哈巴河县| 苍溪县| 靖江市| 黄龙县| 吉水县| 黄陵县| 神木县|