vue3实现跨页面缓存

避免频繁向后端发送请求,vue3中,可以用缓存机制,为了实现跨页面缓存,可以把缓存放到localsotrage里面

关键代码:

const globalCache = JSON.parse(localStorage.getItem('globalCache')) || {};

然后加一个forceRefresh关键字,

const fetchData = async (forceRefresh = false) => {

const cacheKey = `{userId.value}-{currentPage.value}-${pageSize.value}`;

if (!forceRefresh && globalCachecacheKey) {

myStores.value = globalCachecacheKey.data;

totalCount.value = globalCachecacheKey.total_count;

return;

}

让缓存从globalCache里面取,

完整代码:

javascript 复制代码
<template>
  <!-- 清空缓存按钮 -->
  <router-link to="/home" custom v-slot="{ navigate }">
    <van-button 
      type="default" 
      @click="
        // 清空全局缓存对象的所有属性
        Object.keys(globalCache).forEach(key => delete globalCache[key]);
        // 强制刷新数据(跳过缓存)
        fetchData(true);
        navigate();
      " 
      size="small"
    >
      打卡店铺
    </van-button>
  </router-link>
</template>

<script setup>
// 缓存系统核心实现
// ------------------------------------------------------------------
// 初始化全局缓存:从 localStorage 加载已有缓存或创建空对象
const globalCache = JSON.parse(localStorage.getItem('globalCache')) || {};

// 缓存更新方法
const updateCache = (cacheKey, data) => {
  // 将新数据存入缓存对象
  globalCache[cacheKey] = data;
  // 同步更新到 localStorage 持久化存储
  localStorage.setItem('globalCache', JSON.stringify(globalCache));
};

// 清空缓存方法
const clearCache = () => {
  // 遍历删除缓存对象所有属性
  Object.keys(globalCache).forEach(key => delete globalCache[key]);
  // 清除 localStorage 中的持久化存储
  localStorage.removeItem('globalCache');
};

// 数据获取逻辑(带缓存机制)
const fetchData = async (forceRefresh = false) => {
  // 生成当前请求的缓存键(用户ID+分页参数)
  const cacheKey = `${userId.value}-${currentPage.value}-${pageSize.value}`;
  
  // 缓存命中逻辑(当非强制刷新且存在有效缓存时)
  if (!forceRefresh && globalCache[cacheKey]) {
    // 从缓存读取数据
    myStores.value = globalCache[cacheKey].data;
    totalCount.value = globalCache[cacheKey].total_count;
    return;
  }

  // 无有效缓存时发起网络请求
  const response = await axios.get(`${baseURL}/query_store/${userId.value}?page=${currentPage.value}&pageSize=${pageSize.value}`);
  
  // 更新响应数据到缓存系统
  updateCache(cacheKey, {
    data: response.data.data,
    total_count: response.data.total_count,
  });
};

// 路由导航守卫(控制页面离开时的缓存清理)
onBeforeRouteLeave((to, from, next) => {
  // 仅当跳转到信息填报页面时保留缓存
  if (to.name === 'informationFill') {
    next();
  } else {
    // 其他路由跳转时清空缓存
    clearCache();
    next();
  }
});
</script>
相关推荐
医疗信息化王工9 小时前
医院自律端系统——预警处置模块全栈实战(ASP.NET Core + Vue3 + Quartz 定时调度)
mysql·postgresql·vue·asp.net core·quartz
颜笑晏晏11 小时前
长输入短输出场景下的 SGLang 推理性能实测前缀缓存、PD 分离配比与参数调优
缓存·推理优化·sglang·ai infra·pd分离
大大杰哥12 小时前
Vue2学习(1)--了解基本方法与概念
javascript·学习·vue
真实的菜12 小时前
Redis 从入门到精通(十四):Redis 7.x 新特性全解 —— 系列收官之作
数据库·redis·缓存
小小工匠13 小时前
Redis - 缓存与数据库一致性:问题分析与解决方案
redis·缓存·性能优化·消息队列·并发
闪电悠米14 小时前
黑马点评-Redis 消息队列-02_list_pubsub_limits
java·数据库·ide·redis·缓存·list·intellij-idea
折哥的程序人生 · 物流技术专研14 小时前
《Java 100 天进阶之路》第93篇:Redis实战应用:缓存策略与分布式锁(2026版)
java·redis·缓存·面试·架构·求职招聘
填满你的记忆14 小时前
10万QPS下,Redis缓存如何避免雪崩?
数据库·redis·缓存
10WTW0114 小时前
QQ本地缓存机制初步探寻
缓存·视频·md5
2601_9611940215 小时前
考研专业课在哪里参加考试|考点|流程|资料已整理
linux·考研·ubuntu·缓存·centos·负载均衡