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

溫馨提示×

溫馨提示×

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

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

Vue3里的EffectScope怎么使用

發布時間:2022-08-08 11:43:35 來源:億速云 閱讀:232 作者:iii 欄目:開發技術

本篇內容介紹了“Vue3里的EffectScope怎么使用”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!

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

const scope = effectScope()

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

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

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

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

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

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

示例代碼,參考鏈接

const disposables = []

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

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

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

disposables.push(stopWatch2)

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

disposables.push(stopWatch3)

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

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

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

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

它還提供了從組件的 setup() 范圍或用戶定義的范圍創建“分離” 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
    }
}

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

“Vue3里的EffectScope怎么使用”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注億速云網站,小編將為大家輸出更多高質量的實用文章!

向AI問一下細節

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

AI

柳江县| 尚志市| 登封市| 分宜县| 灵川县| 东莞市| 黄龙县| 东乌| 大渡口区| 遂平县| 鄂托克前旗| 孟津县| 霍州市| 运城市| 广东省| 偏关县| 揭东县| 孟连| 青浦区| 昌宁县| 东港市| 和顺县| 乐平市| 个旧市| 阜康市| 定南县| 塔河县| 沂水县| 九龙坡区| 威信县| 都江堰市| 浦北县| 金坛市| 宁晋县| 麦盖提县| 广汉市| 马公市| 和平县| 苏州市| 珠海市| 陇西县|