Vuex和前端緩存的整合策略詳解
如何存放或更新緩存?
緩存數(shù)據(jù)來(lái)源是預(yù)知的,我們可以預(yù)先定義哪些 mutation 是緩存相關(guān)的。
我們期望這個(gè)過(guò)程更自然一點(diǎn),通過(guò)某種變化自動(dòng)映射,使以后不管緩存類(lèi)別增加還是減少都能修改極少的代碼來(lái)應(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 中加入緩存判斷。
action fetchData({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)足夠完成緩存 讀取 --> 更新 的工作了。但試想一下將來(lái)某個(gè)其他數(shù)據(jù)類(lèi)別要做緩存,我們就要把上面的代碼格式再搬一遍。
即:把新的需要緩存的數(shù)據(jù)類(lèi)別對(duì)應(yīng)的 mutationType 加 cacheKey 后綴,把獲取數(shù)據(jù)的 action 中加緩存判斷。
雖然實(shí)際編碼中也沒(méi)有多大的工作量,但感覺(jué)還不是最好的開(kāi)發(fā)體驗(yàn)。
action優(yōu)化
action 中的痛點(diǎn)是:每次都需要重復(fù)寫(xiě)緩存判斷。可以把這個(gè)判斷過(guò)程拿出來(lái)放到一個(gè)大家都能訪(fǎng)問(wèn)到的公共的地方,且最好是與 Vuex 契合的。
Vuex 支持 action 相互調(diào)用,我們可以設(shè)置一個(gè)單獨(dú)的 action 用來(lái)提交。
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)在于:加后綴?。〖雍缶Y?。?!
如果一個(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ù)類(lèi)別,我們就可以基于 module 作緩存識(shí)別。
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) } })
當(dāng)我們需要新增或減少緩存數(shù)據(jù),只需要去 cacheConfig 中增加或減少一項(xiàng)模塊配置。
總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作能帶來(lái)一定的幫助,如果有疑問(wèn)大家可以留言交流,謝謝大家對(duì)腳本之家的支持。
相關(guān)文章
VUE實(shí)現(xiàn)移動(dòng)端列表篩選功能
這篇文章主要介紹了VUE實(shí)現(xiàn)移動(dòng)端列表篩選功能,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-08-08前端vue-cropperjs實(shí)現(xiàn)圖片裁剪方案
這篇文章主要為大家介紹了前端vue-cropperjs實(shí)現(xiàn)圖片裁剪方案,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-07-07Vue3在jsx下父子組件實(shí)現(xiàn)使用插槽方式
這篇文章主要介紹了Vue3在jsx下父子組件實(shí)現(xiàn)使用插槽方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-10-10基于Vant UI框架實(shí)現(xiàn)時(shí)間段選擇器
這篇文章主要為大家詳細(xì)介紹了基于Vant UI框架實(shí)現(xiàn)時(shí)間段選擇器,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-12-12在vue中實(shí)現(xiàn)清除echarts上次保留的數(shù)據(jù)(親測(cè)有效)
這篇文章主要介紹了在vue中實(shí)現(xiàn)清除echarts上次保留的數(shù)據(jù)(親測(cè)有效),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-09-09解決vue create 創(chuàng)建項(xiàng)目只有兩個(gè)文件問(wèn)題
這篇文章主要介紹了解決vue create 創(chuàng)建項(xiàng)目只有兩個(gè)文件問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-02-02