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

深入理解Vue3里的EffectScope

 更新時間:2022年08月07日 11:53:39   作者:前端精髓  
本文主要介紹了Vue3里的EffectScope,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

Vue 3.2 版本引入了新的 Effect scope API,使用 effectScope 創(chuàng)建一個 effect 作用域,可以捕獲其中所創(chuàng)建的響應(yīng)式副作用 (即計算屬性和偵聽器),這樣捕獲到的副作用可以一起處理。使用 getCurrentScope 返回當前活躍的 effect 作用域。使用 onScopeDispose 在當前活躍的 effect 作用域上注冊一個處理回調(diào)函數(shù)。當相關(guān)的 effect 作用域停止時會調(diào)用這個回調(diào)函數(shù)。

const scope = effectScope()

scope.run(() => {
  const doubled = computed(() => counter.value * 2)

  watch(doubled, () => console.log(doubled.value))

  watchEffect(() => console.log('Count: ', doubled.value))
})

// 處理掉當前作用域內(nèi)的所有 effect
scope.stop()

在 Vue 的 setup 中,響應(yīng)會在開始初始化的時候被收集,在實例被卸載的時候,響應(yīng)就會自動的被取消追蹤了,這時一個很方便的特性。

但是,當我們在組件外使用或者編寫一個獨立的包時,這會變得非常麻煩。當在單獨的文件中,我們該如何停止 computed & watch 的響應(yīng)式依賴呢?

示例代碼,參考鏈接

const disposables = []

const counter = ref(0)
const doubled = computed(() => counter.value * 2)

disposables.push(() => stop(doubled.effect))

const stopWatch1 = watchEffect(() => {
  console.log(`counter: ${counter.value}`)
})

disposables.push(stopWatch1)

const stopWatch2 = watch(doubled, () => {
  console.log(doubled.value)
})

disposables.push(stopWatch2)

上面的代碼中,我們寫了一共三個 computed & watch 的響應(yīng)式依賴,把這些響應(yīng)式依賴的 stopHandle 都存到一個數(shù)組中,意思是我們需要維護這個數(shù)組,這樣將來在需要的時候,就可以像下面這樣,直接把所有的響應(yīng)都停掉:

disposables.forEach((f) => f())
disposables = []

尤其是當我們有一些長而復(fù)雜的組合式函數(shù)代碼時,手動收集所有響應(yīng)式依賴是很費力的。也很容易忘記收集它們(或者您無法訪問在組合式函數(shù)中創(chuàng)建的響應(yīng)式依賴),這可能會導(dǎo)致內(nèi)存泄漏和意外行為。

該特性就是試圖將組件的 setup() 響應(yīng)式依賴收集和處理功能抽象為更通用的 API,該 API 可以在組件模型之外復(fù)用。

它還提供了從組件的 setup() 范圍或用戶定義的范圍創(chuàng)建“分離” effects 的功能。

這個功能解決了什么問題?

// global shared reactive state
let foo

function useFoo() {
  if (!foo) { // lazy initialization
      foo = ref()
      watch(foo, ...) // <- this is stopped when component that created it is unmounted
      // make some http calls etc
  }
  return foo
}

component1 = {
    setup() {
        useFoo() // lazily initialize
    }
}

component2 = {
    setup() {
        useFoo() // lazily initialize
    }
}

我有一個在多個組件之間共享功能的組合式函數(shù),問題是當卸載第一個調(diào)用的組件時 component1 停止 useFoo 響應(yīng)式依賴。因為如果不停止對全局變量 foo 又有影響,其他 component2 組件調(diào)用有問題。

到此這篇關(guān)于深入理解Vue3里的EffectScope的文章就介紹到這了,更多相關(guān)Vue3 EffectScope內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • vue Tab切換以及緩存頁面處理的幾種方式

    vue Tab切換以及緩存頁面處理的幾種方式

    這篇文章主要介紹了vue Tab切換以及緩存頁面處理的幾種方式,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-11-11
  • vue中實現(xiàn)拖拽排序功能的詳細教程

    vue中實現(xiàn)拖拽排序功能的詳細教程

    在業(yè)務(wù)中列表拖拽排序是比較常見的需求,下面這篇文章主要給大家介紹了關(guān)于vue中實現(xiàn)拖拽排序功能的詳細教程,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2022-08-08
  • vue3手動刪除keepAlive緩存的方法

    vue3手動刪除keepAlive緩存的方法

    當我們未設(shè)置keepAlive的最大緩存數(shù)時,當緩存組件太多,會導(dǎo)致內(nèi)存溢出,本文給大家介紹了vue3手動刪除keepAlive緩存的方法,文中通過代碼示例介紹的非常詳細,需要的朋友可以參考下
    2024-03-03
  • vue實現(xiàn)三級聯(lián)動動態(tài)菜單

    vue實現(xiàn)三級聯(lián)動動態(tài)菜單

    這篇文章主要為大家詳細介紹了vue實現(xiàn)三級聯(lián)動動態(tài)菜單,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-04-04
  • vue下拉列表功能實例代碼

    vue下拉列表功能實例代碼

    這篇文章主要介紹了vue下拉列表功能實例代碼,非常不錯,具有參考借鑒價值,需要的朋友可以參考下
    2018-04-04
  • vue前端信息詳情頁模板梳理詳解

    vue前端信息詳情頁模板梳理詳解

    這篇文章主要為大家詳細介紹了vue前端信息詳情頁模板梳理,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-04-04
  • vue3實現(xiàn)多層級列表的項目實踐

    vue3實現(xiàn)多層級列表的項目實踐

    本文主要介紹了vue3實現(xiàn)多層級列表的項目實踐,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-07-07
  • vue3+element-plus動態(tài)路由菜單示例代碼

    vue3+element-plus動態(tài)路由菜單示例代碼

    這篇文章主要介紹了vue3+element-plus動態(tài)路由菜單示例代碼,代碼簡單易懂,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-11-11
  • 可控制緩存銷毀的?keepAlive?組件實現(xiàn)詳解

    可控制緩存銷毀的?keepAlive?組件實現(xiàn)詳解

    這篇文章主要為大家介紹了可控制緩存銷毀的?keepAlive?組件實現(xiàn)詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-10-10
  • vue實現(xiàn)購物車的監(jiān)聽

    vue實現(xiàn)購物車的監(jiān)聽

    這篇文章主要為大家詳細介紹了利用vue的監(jiān)聽事件實現(xiàn)一個簡單購物車,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-04-04

最新評論