使用vuex缓存数据并优化自己的vuex-cache
网络编程 2021-07-04 16:45www.168986.cn编程入门
这篇文章主要介绍了使用vuex缓存数据并优化自己的vuex-cache,长沙网络推广觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随长沙网络推广过来看看吧
需求
- 请求接口之后,缓存当前接口的数据,下次请求同一接口时拿缓存数据,不再重新请求
- 添加缓存失效时间
cache使用map来实现
ES6 模块与 CommonJS 模块的差异
- CommonJS 模块输出的是一个值的拷贝,ES6 模块输出的是值的引用。
- CommonJS 模块是运行时加载,ES6 模块是编译时输出接口。
因为esm输出的是值的引用,直接就是单例模式了
export let cache = new Cache()
版本1
思路
- 在vuex注册插件,插件会在每次mutations提交之后,判断要不要写入cache
- 在提交actions的时候判断是否有cache,有就拿cache里面的数据,然后把数据mit给mutataios
注意 在插件里面获取的mutations-type是包含命名空间的,而在actions里面则是没有命名空间,需要补全。
/mutation-types.js
/ 需要缓存的数据会在mutations-type后面添加-CACHED / export const SET_HOME_INDEX = 'SET_HOME_INDEX-CACHED' /modules/home/index.js const actions = { / @description 如果有缓存,就返回把缓存的数据,传入mutations, 没有缓存就从接口拿数据,存入缓存,把数据传入mutations / async fetchAction ({mit}, {mutationType, fetchData, oPayload}) { // vuex开启了命名空间,所这里从cachekey要把命名空间前缀 + type + 把payload格式化成JSON const cacheKey = NAMESPACE + mutationType + JSON.stringify(oPayload) const cacheResponse = cache.get(cacheKey || '') if (!cacheResponse) { const [err, response] = await fetchData() if (err) { console.error(err, 'error in fetchAction') return false } mit(mutationType, {response: response, oPayload}) } else { console.log('已经进入缓存取数据!!!') mit(mutationType, {response: cacheResponse, oPayload}) } }, loadHomeData ({ dispatch, mit }) { dispatch( 'fetchAction', { mutationType: SET_HOME_INDEX, fetchData: api.index, } ) } } const mutations = { [SET_HOME_INDEX] (state, {response, oPayload}) {}, } const state = { indexData: {} } export default { namespaced: NAMESPACED, actions, state, getters, mutations }
编写插件,在这里拦截mutations,判断是否要缓存
/plugin/cache.js
import cache from 'src/store/util/CacheOfStore' // import {strOfPayloadQuery} from 'src/store/util/index' / 在每次mutations提交之后,把mutations-type后面有CACHED标志的数据存入缓存, 现在key值是mutations-type 问题 没办法区分不同参数query的请求, 方法1: 用每个mutations-type + payload的json格式为key来缓存数据 / function cachePlugin () { return store => { store.subscribe(({ type, payload }, state) => { // 需要缓存的数据会在mutations-type后面添加CACHED const needCache = type.split('-').pop() === 'CACHED' if (needCache) { // 这里的type会自动加入命名空间所以 cacheKey = type + 把payload格式化成JSON const cacheKey = type + JSON.stringify(payload && payload.oPayload) const cacheResponse = cache.get(cacheKey) // 如果没有缓存就存入缓存 if (!cacheResponse) { cache.set(cacheKey, payload.response) } } console.log(cache) }) } } const plugin = cachePlugin() export default plugin
store/index.js
import Vue from 'vue' import Vuex from 'vuex' import home from './modules/home' import cachePlugin from './plugins/cache' Vue.use(Vuex) const store = new Vuex.Store({ modules: { home, editActivity, editGuide } plugins: [cachePlugin] }) export default store
版本2
思路直接包装fetch函数,在里面里面判断是否需要缓存,缓存是否超时。
优化点
- 把原本分散的cache操作统一放入到fetch
- 减少了对命名空间的操作
- 添加了缓存有效时间
/actions.js
const actions = { async loadHomeData ({ dispatch, mit }, oPayload) { mit(SET_HOME_LOADSTATUS) const [err, response] = await fetchOrCache({ api: api.index, queryArr: oPayload.queryArr, mutationType: SET_HOME_INDEX }) if (err) { console.log(err, 'loadHomeData error') return [err, response] } mit(SET_HOME_INDEX, { response }) return [err, response] } }
在fetchOrCache判断是需要缓存,还是请求接口
/ 用这个函数就说明是需要进入缓存 @param {} api 请求的接口 @param {} queryArr 请求的参数 @param {} mutationType 传入mutationType作为cache的key值 / export async function fetchOrCache ({api, queryArr, mutationType, diff}) { // 这里是请求接口 const fetch = httpGet(api, queryArr) const cachekey = `${mutationType}:${JSON.stringify(queryArr)}` if (cache.has(cachekey)) { const obj = cache.get(cachekey) if (cacheFresh(obj.cacheTimestemp, diff)) { return cloneDeep(obj) } else { // 超时就删除 cache.delete(cachekey) } } // 不取缓存的处理 let response = await fetch() // 时间戳绑定在数组的属性上 response.cacheTimestemp = Date.now() cache.set(cachekey, response) // 返回cloneDeep的对象 return cloneDeep(response) } / 判断缓存是否失效 @param {} diff 失效时间差,默认15分钟=900s / const cacheFresh = (cacheTimestemp, diff = 900) => { if (cacheTimestemp) { return ((Date.now() - cacheTimestemp) / 1000) <= diff } else { return true } }
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持狼蚁SEO。
编程语言
- 如何快速学会编程 如何快速学会ug编程
- 免费学编程的app 推荐12个免费学编程的好网站
- 电脑怎么编程:电脑怎么编程网咯游戏菜单图标
- 如何写代码新手教学 如何写代码新手教学手机
- 基础编程入门教程视频 基础编程入门教程视频华
- 编程演示:编程演示浦丰投针过程
- 乐高编程加盟 乐高积木编程加盟
- 跟我学plc编程 plc编程自学入门视频教程
- ug编程成航林总 ug编程实战视频
- 孩子学编程的好处和坏处
- 初学者学编程该从哪里开始 新手学编程从哪里入
- 慢走丝编程 慢走丝编程难学吗
- 国内十强少儿编程机构 中国少儿编程机构十强有
- 成人计算机速成培训班 成人计算机速成培训班办
- 孩子学编程网上课程哪家好 儿童学编程比较好的
- 代码编程教学入门软件 代码编程教程