国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 語言 > JavaScript > 正文

Vuex和前端緩存的整合策略詳解

2024-05-06 15:17:28
字體:
供稿:網(wǎng)友

如何存放或更新緩存?

緩存數(shù)據(jù)來源是預(yù)知的,我們可以預(yù)先定義哪些 mutation 是緩存相關(guān)的。

我們期望這個(gè)過程更自然一點(diǎn),通過某種變化自動(dòng)映射,使以后不管緩存類別增加還是減少都能修改極少的代碼來應(yīng)對(duì)變化。

Vuex的插件可以攔截 mutations,借助這個(gè)機(jī)制,我們可以制定一種策略化的規(guī)則。

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

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

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

如何從緩存取數(shù)據(jù)避免請(qǐng)求?

只需要在緩存相關(guān)的 action 中加入緩存判斷。

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

設(shè)計(jì)優(yōu)化

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

即:把新的需要緩存的數(shù)據(jù)類別對(duì)應(yīng)的 mutationType 加 cacheKey 后綴,把獲取數(shù)據(jù)的 action 中加緩存判斷。

雖然實(shí)際編碼中也沒有多大的工作量,但感覺還不是最好的開發(fā)體驗(yàn)。

action優(yōu)化

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

Vuex 支持 action 相互調(diào)用,我們可以設(shè)置一個(gè)單獨(dú)的 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)}

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

mutation優(yōu)化

mutation 的痛點(diǎn)在于:加后綴啊!加后綴啊!!

如果一個(gè)數(shù)據(jù)的相關(guān)邏輯復(fù)雜,可能對(duì)應(yīng)很多個(gè) mutationType,每個(gè)都需要:加后綴!

要是代碼能自動(dòng)識(shí)別需要走緩存的 mutationType 就完美了!

mutationType 默認(rèn)的格式為 module-type,假如業(yè)務(wù)中一個(gè) module 對(duì)應(yīng)一個(gè)數(shù)據(jù)類別,我們就可以基于 module 作緩存識(shí)別。

cacheConfig.jsexport default { module1: 'key1', module2: 'key2', //...}
actioncommitAction({ 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)}interceptorstore.subscribe(({ type, payload }) => { const module = type.split('-')[0] const cacheKey = CacheConfig[module] if (cacheKey) {  Cache.save(cacheKey, payload) }})            
發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表

圖片精選

主站蜘蛛池模板: 漾濞| 前郭尔| 肇庆市| 七台河市| 民丰县| 合江县| 永仁县| 台中市| 吉隆县| 衡水市| 墨竹工卡县| 遂昌县| 雷波县| 柳州市| 河间市| 葫芦岛市| 武宣县| 大悟县| 平邑县| 商南县| 隆子县| 平果县| 广西| 通城县| 乌拉特前旗| 滨州市| 杂多县| 南昌市| 古蔺县| 淳化县| 太湖县| 邛崃市| 乌兰浩特市| 泸定县| 昔阳县| 浑源县| 益阳市| 高安市| 偏关县| 万盛区| 陇南市|