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

詳解Vue中是如何實現(xiàn)cache緩存的

 更新時間:2023年07月03日 14:06:45   作者:翰玥  
這篇文章分享一個比較有意思的東西,那就是Vue中如何實現(xiàn)cache緩存的,文中的示例代碼講解詳細,感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下

這篇文章分享一個比較有意思的東西,那就是Vue中如何實現(xiàn)cache緩存的。提前揭曉答案--閉包。下面我們就來手寫一個吧。第一步,毫無疑問當(dāng)然是我們的測試文件咯。

添加測試文件

繼續(xù)使用vitest測試,想知道具體怎么操作的,可以看下專欄第一篇文章。

剛開始學(xué)習(xí)寫測試,大家多提意見哈。

test.only("cached", () => {
  const fnMock = vi.fn((str) => str)
  const getName = cached(fnMock)
  const name = getName("mick")
  expect(name).toBe("mick")
  expect(fnMock).toHaveBeenCalled()
  expect(fnMock).toHaveBeenCalledTimes(1)
  const name1 = getName("mick")
  expect(name1).toBe("mick")
  expect(fnMock).toHaveBeenCalledTimes(1)
})

首先模擬一個函數(shù),這個函數(shù)傳入一個字符串,返回一個字符串。為什么要這么模擬呢?我們拿Vue當(dāng)中capitalize首字母轉(zhuǎn)大寫舉例(當(dāng)然我們可以暫時不用太多的關(guān)心capitalize是怎么實現(xiàn)的)

const capitalize = cached((str) => {
  return str.charAt(0).toUpperCase() + str.slice(1)
})

可以看到cached傳入了一個函數(shù),這個函數(shù)要實現(xiàn)的就是傳入一個字符串,返回一個字符串(首字母轉(zhuǎn)成大寫)。所以我們要模擬的就是類似這樣的一個函數(shù)。

回歸正題

模擬了一個函數(shù)fnMock,傳給cached并執(zhí)行,返回了getName函數(shù)。然后調(diào)用getName函數(shù)傳入字符串mick,用name變量接收,這個變量我們期望應(yīng)該是mick。此時模擬的fnMock應(yīng)該被調(diào)用了一次,當(dāng)再次執(zhí)行getName函數(shù)同樣傳入mick時,仍然能拿到這個值,但是模擬的fnMock還是被調(diào)用一次。因為mick被緩存了。

沒錯,就是用文章開頭提到的"閉包"解決。

實現(xiàn)cache

不廢話,直接上代碼

export function cached(fn) {
  const cache = Object.create(null)
  return function cachedFn(str) {
    var hit = cache[str]
    return hit || (cache[str] = fn(str))
  }
}

首先創(chuàng)建一個空對象方便存儲需要緩存的值。然后返回一個函數(shù)cachedFn,參數(shù)fn就是就是我們測試中的fnMock,函數(shù)內(nèi)部首先去獲取我們想要拿到的值cache[str],第一次肯定是拿不到的,所以需要對其賦值cache[str] = fn(str)并返回,此時fnMock已經(jīng)被執(zhí)行了1次。此時根據(jù)閉包的特性,傳入的str已經(jīng)被緩存了起來。當(dāng)?shù)诙蝹魅胪瑯拥闹档臅r候,var hit = cache[str]就可以獲取到了,則直接返回,所以fnMock不會被再次執(zhí)行,只有首次執(zhí)行了1次。

到此這篇關(guān)于詳解Vue中是如何實現(xiàn)cache緩存的的文章就介紹到這了,更多相關(guān)Vue cache緩存內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • vue之Element-Ui輸入框顯示與隱藏方式

    vue之Element-Ui輸入框顯示與隱藏方式

    這篇文章主要介紹了vue之Element-Ui輸入框顯示與隱藏方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-04-04
  • vue+iview tabs context-menu 彈出框修改樣式的方法

    vue+iview tabs context-menu 彈出框修改樣式的方法

    今天遇到一個需求說頁面頂部的菜單右鍵彈出框離得有點遠,需要我們做調(diào)整,下面小編給大家分享下vue+iview tabs context-menu 彈出框修改樣式的方法,感興趣的朋友跟隨小編一起看看吧
    2024-06-06
  • 詳解Vue中watch的高級用法

    詳解Vue中watch的高級用法

    我們通過實例代碼給大家分享了Vue中watch的高級用法,對此知識點有需要的朋友可以跟著學(xué)習(xí)下。
    2018-05-05
  • Vue和React有哪些區(qū)別

    Vue和React有哪些區(qū)別

    這篇文章主要介紹了Vue和React有哪些區(qū)別,幫助大家更好的理解和學(xué)習(xí)JavaScript框架,感興趣的朋友可以了解下
    2020-09-09
  • Vue.js實現(xiàn)的表格增加刪除demo示例

    Vue.js實現(xiàn)的表格增加刪除demo示例

    這篇文章主要介紹了Vue.js實現(xiàn)的表格增加刪除demo,結(jié)合實例形式分析了vue.js數(shù)據(jù)綁定及元素增加、刪除等相關(guān)操作技巧,需要的朋友可以參考下
    2018-05-05
  • 使用async-validator編寫Form組件的方法

    使用async-validator編寫Form組件的方法

    本篇文章主要介紹了使用 async-validator 編寫 Form 組件的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-01-01
  • 深入詳解Vue3中的Mock數(shù)據(jù)模擬

    深入詳解Vue3中的Mock數(shù)據(jù)模擬

    這篇文章主要為大家介紹了深入Vue3中的Mock數(shù)據(jù)模擬實現(xiàn)細節(jié)詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-05-05
  • Vuex如何獲取getter對象中的值(包括module中的getter)

    Vuex如何獲取getter對象中的值(包括module中的getter)

    這篇文章主要介紹了Vuex如何獲取getter對象中的值(包括module中的getter),具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-08-08
  • vue-devtools的安裝和使用步驟詳解

    vue-devtools的安裝和使用步驟詳解

    在本篇文章中小編給大家整理的是一篇關(guān)于vue-devtools安裝使用的相關(guān)知識點內(nèi)容,有需要的朋友們可以學(xué)習(xí)下。
    2019-10-10
  • 快速解決vue動態(tài)綁定多個class的官方實例語法無效的問題

    快速解決vue動態(tài)綁定多個class的官方實例語法無效的問題

    今天小編就為大家分享一篇快速解決vue動態(tài)綁定多個class的官方實例語法無效的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-09-09

最新評論