中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

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

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

Vuex和前端緩存怎么整合

發布時間:2022-10-28 09:50:32 來源:億速云 閱讀:109 作者:iii 欄目:開發技術

今天小編給大家分享一下Vuex和前端緩存怎么整合的相關知識點,內容詳細,邏輯清晰,相信大部分人都還太了解這方面的知識,所以分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后有所收獲,下面我們一起來了解一下吧。

如何存放或更新緩存?

緩存數據來源是預知的,我們可以預先定義哪些 mutation 是緩存相關的。

我們期望這個過程更自然一點,通過某種變化自動映射,使以后不管緩存類別增加還是減少都能修改極少的代碼來應對變化。

Vuex的插件可以攔截 mutations,借助這個機制,我們可以制定一種策略化的規則。

可以規定,所有需要更新緩存的 mutationType 都要符合這種格式:module-type-cacheKey,非緩存的 mutationType 格式為 module-type。

那么就可以攔截 mutation,去做我們想做的事了:

store.subscribe(({ type, payload }) => {
 const cacheKey = type.split('-')[2]
 if (cacheKey) {
  Cache.save(cacheKey, payload)
 }
})

如何從緩存取數據避免請求?

只需要在緩存相關的 action 中加入緩存判斷。

action
fetchData({commit}) {
 const cacheData = Cache.get(cacheKey)
 if(!cacheData) {
  Api.getData().then(data => {
   commit(mutationType, data)
  })
 } else {
  commit(mutationType, cacheData)
 }
}

設計優化

以上的確已經足夠完成緩存 讀取 --> 更新 的工作了。但試想一下將來某個其他數據類別要做緩存,我們就要把上面的代碼格式再搬一遍。

即:把新的需要緩存的數據類別對應的 mutationType 加 cacheKey 后綴,把獲取數據的 action 中加緩存判斷。

雖然實際編碼中也沒有多大的工作量,但感覺還不是最好的開發體驗。

action優化

action 中的痛點是:每次都需要重復寫緩存判斷。可以把這個判斷過程拿出來放到一個大家都能訪問到的公共的地方,且最好是與 Vuex 契合的。

Vuex 支持 action 相互調用,我們可以設置一個單獨的 action 用來提交。

commitAction({ commit }, mutationType, getData) {
 const cacheKey = mutationType.split('-')[2]
 const cacheData = Cache.get(cacheKey || '')
 if(!cacheData) {
  getData().then(data => {
   commit(mutationType, data)
  })
 } else {
  commit(mutationType, cacheData)
 }
},
fetchData({ dispatch }) {
 dispatch('commitAction', mutationType, Api.getData)
}

不管是否需要緩存最終都走同一個 action 去提交,由這個 action 去做決策。

mutation優化

mutation 的痛點在于:加后綴啊!加后綴啊!!

如果一個數據的相關邏輯復雜,可能對應很多個 mutationType,每個都需要:加后綴!

要是代碼能自動識別需要走緩存的 mutationType 就完美了!

mutationType 默認的格式為 module-type,假如業務中一個 module 對應一個數據類別,我們就可以基于 module 作緩存識別。

cacheConfig.js
export default {
 module1: 'key1',
 module2: 'key2',
 //...
}
action
commitAction({ commit }, mutationType, getData) {
 const module = mutationType.split('-')[0]
 const cacheKey = CacheConfig[module] || ''
 const cacheData = Cache.get(cacheKey)
 if(!cacheData) {
  getData().then(data => {
   commit(mutationType, data)
  })
 } else {
  commit(mutationType, cacheData)
 }
},
fetchData({ dispatch }) {
 dispatch('commitAction', mutationType, Api.getData)
}
interceptor
store.subscribe(({ type, payload }) => {
 const module = type.split('-')[0]
 const cacheKey = CacheConfig[module]
 if (cacheKey) {
  Cache.save(cacheKey, payload)
 }
})

當我們需要新增或減少緩存數據,只需要去 cacheConfig 中增加或減少一項模塊配置。

以上就是“Vuex和前端緩存怎么整合”這篇文章的所有內容,感謝各位的閱讀!相信大家閱讀完這篇文章都有很大的收獲,小編每天都會為大家更新不同的知識,如果還想學習更多的知識,請關注億速云行業資訊頻道。

向AI問一下細節

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

AI

平武县| 辛集市| 济宁市| 淮南市| 诸城市| 靖江市| 永济市| 军事| 惠东县| 祁东县| 荆门市| 周宁县| 安多县| 大城县| 林口县| 随州市| 通山县| 咸宁市| 梓潼县| 卫辉市| 邵阳县| 莆田市| 修武县| 东阳市| 奉贤区| 克什克腾旗| 安吉县| 定兴县| 深水埗区| 德阳市| 宜阳县| 建瓯市| 石楼县| 黄冈市| 莎车县| 濮阳市| 亚东县| 淮南市| 漯河市| 轮台县| 涞源县|