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

深入理解Vue3 computed

 更新時間:2025年08月27日 09:21:05   作者:前端小巷子  
本文主要介紹了Vue3 computed的使用,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧

在模板里寫一行 {{ sum }},背后卻藏著「惰性求值 + 精準依賴收集 + 臟檢查緩存」的三重魔法。本文帶你鉆進源碼,拆解 computed 如何決定「何時算、何時不、為何不能異步」。

一、使用方法

const state = reactive({ a: 1, b: 2 })
const sum = computed(() => state.a + state.b)

console.log(sum.value) // 3
state.a = 10
console.log(sum.value) // 12

看似普通,但注意兩點:

  • 只讀:sum 不是函數(shù),而是一個「帶緩存的 getter」。
  • 懶執(zhí)行:直到第一次讀取 value,計算函數(shù)才真正跑一遍。

二、緩存機制:dirty 標志位

源碼核心只有兩行狀態(tài)機:

let value: any
let dirty = true
  • dirty 為 true → 需要重新計算
  • dirty 為 false → 直接返回舊值

首次讀取 sum.value 時,dirty 從 true 變?yōu)?false,并把結(jié)果存入 value。

當依賴的響應式數(shù)據(jù)變化,調(diào)度器把 dirty 重新置為 true,但不會立即計算,而是等待下一次讀取。

這就是「緩存」的本質(zhì):用 1 bit 的布爾值換一次昂貴的計算。

三、依賴收集:effect 包裹 getter

computed 的計算函數(shù)被 effect 包裝成副作用:

const effectFn = effect(getter, {
  lazy: true,
  scheduler() {
    dirty = true
    trigger(obj, TriggerOpTypes.SET, 'value')
  }
})
  • lazy: true 阻止首次執(zhí)行,實現(xiàn)惰性求值。
  • scheduler 在依賴變化時只打標記,不立即重算,確保緩存語義。

當模板讀取 sum.value,track 把當前渲染副作用注冊到 computed 的依賴圖;當 state.a 變化,trigger 通知渲染器重新執(zhí)行,渲染器再去讀 sum.value,此時才真正觸發(fā)計算。

四、為什么拒絕異步?

設想一個異步 computed:

const asyncSum = computed(async () => {
  const res = await fetch('/api/sum?a=' + state.a)
  return res.json()
})

問題立刻暴露:

  1. 緩存無法兌現(xiàn)

    第一次讀取返回一個 Promise,第二次讀取依賴并未變化,但緩存里存的是 Promise,無法直接返回結(jié)果。

  2. 渲染時數(shù)據(jù)缺位

    模板在渲染階段需要同步值,異步導致視圖出現(xiàn)空檔或閃爍。

  3. 依賴追蹤混亂

    異步完成時間不確定,期間若依賴再次變化,無法確定哪一次結(jié)果是最新。

Vue 官方給出的替代方案是 watch + ref

const asyncSum = ref(0)
watch(state, async () => {
  asyncSum.value = await fetch('/api/sum?a=' + state.a).then(r => r.json())
})

watch 不緩存、不阻塞渲染,天然適合異步副作用。

五、可寫 computed:緩存 + setter 的雙通道

const fullName = computed({
  get()   { return firstName.value + ' ' + lastName.value },
  set(v)  { [firstName.value, lastName.value] = v.split(' ') }
})
  • getter 走同樣的緩存邏輯。
  • setter 只是普通函數(shù),無緩存要求,因此可以包含異步(但仍不推薦,因為 setter 觸發(fā)后 getter 需同步返回新值)。

總結(jié)

computed 用「dirty 位 + 惰性 effect」實現(xiàn)同步緩存,用「拒絕異步」換取數(shù)據(jù)一致性。理解了這一點,你就掌握了 Vue 性能調(diào)優(yōu)的第一把鑰匙。

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

相關文章

  • 使用vant?自定義彈框全過程

    使用vant?自定義彈框全過程

    這篇文章主要介紹了使用vant?自定義彈框全過程,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-05-05
  • Vue表單demo v-model雙向綁定問題

    Vue表單demo v-model雙向綁定問題

    本文通過實例代碼給大家介紹了Vue表單demo v-model雙向綁定問題,代碼簡單易懂非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下
    2018-06-06
  • Vue3+Element?Plus按需引入(自動導入)詳解

    Vue3+Element?Plus按需引入(自動導入)詳解

    element-plus根據(jù)官網(wǎng)文檔,推薦用戶采用按需導入的方式進行導入,下面這篇文章主要給大家介紹了關于Vue3+Element?Plus按需引入(自動導入)的相關資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2022-10-10
  • vue父組件觸發(fā)事件改變子組件的值的方法實例詳解

    vue父組件觸發(fā)事件改變子組件的值的方法實例詳解

    這篇文章主要介紹了vue父組件觸發(fā)事件改變子組件的值的實例代碼,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-05-05
  • Vue+java實現(xiàn)時間段的搜索示例

    Vue+java實現(xiàn)時間段的搜索示例

    本文主要介紹了Vue+java實現(xiàn)時間段的搜索示例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2022-06-06
  • vue自定義js圖片碎片輪播圖切換效果的實現(xiàn)代碼

    vue自定義js圖片碎片輪播圖切換效果的實現(xiàn)代碼

    這篇文章主要介紹了vue自定義js圖片碎片輪播圖切換效果的實現(xiàn)代碼,需要的朋友可以參考下
    2019-04-04
  • 在vue中封裝可復用的組件方法

    在vue中封裝可復用的組件方法

    下面小編就為大家分享一篇在vue中封裝可復用的組件方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-03-03
  • 使用Vant框架list組件遇到的坑及解決

    使用Vant框架list組件遇到的坑及解決

    這篇文章主要介紹了使用Vant框架list組件遇到的坑及解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-04-04
  • vue如何進行動畫的封裝

    vue如何進行動畫的封裝

    這篇文章主要介紹了vue如何進行動畫的封裝,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-09-09
  • vue?內(nèi)置組件?component?的用法示例詳解

    vue?內(nèi)置組件?component?的用法示例詳解

    這篇文章主要介紹了vue內(nèi)置組件component的用法,本文給大家介紹了component內(nèi)置組件切換方法,通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-08-08

最新評論