如何在javascript中实现缓存机制_怎样设置缓存策略和过期时间?

admin 百科 12
JavaScript缓存需自主管理生命周期,内存缓存用Map+时间戳判断TTL,localStorage需手动添加expiresAt字段,推荐封装支持LRU、TTL和多存储策略的缓存类,并注意异常处理与服务端缓存头协同。

如何在javascript中实现缓存机制_怎样设置缓存策略和过期时间?-第1张图片-佛山资讯网

在 JavaScript 中实现缓存机制,核心是“按需存储 + 主动控制过期”,而不是依赖浏览器自动缓存(如 HTTP Cache),因为 JS 运行在内存或本地存储中,需要自己管理生命周期。

内存缓存(Map 或 Object)+ 时间戳判断

适合短期、高频、轻量数据(如 API 响应、计算结果)。用 Map 存储值和创建时间,读取时检查是否过期:

  • 写入时记录 timestampttl(毫秒)
  • 读取前比对 Date.now() - timestamp > ttl,超时则删除并返回 null
  • 示例:缓存用户信息 5 分钟
const cache = new Map();
function setCache(key, value, ttl = 300000) {
  cache.set(key, { value, timestamp: Date.now(), ttl });
}
function getCache(key) {
  const item = cache.get(key);
  if (!item) return undefined;
  if (Date.now() - item.timestamp > item.ttl) {
    cache.delete(key);
    return undefined;
  }
  return item.value;
}

localStorage / sessionStorage + 过期字段

适合需跨页面/会话保留但有明确时效的数据(如登录态 token、配置项)。浏览器原生存储不支持自动过期,必须手动加字段:

  • 存入时写入 expiresAt(时间戳),读取时校验
  • 避免直接存原始值,统一包装为对象:{ data: ..., expiresAt: 171xxxxxx }
  • 注意:localStorage 容量有限(通常 5–10MB),不适合大文件或大量缓存

封装一个带策略的缓存类(推荐)

把过期、清理、存储方式封装起来,提升复用性。支持 LRU 驱逐 + TTL + 自定义存储目标:

标签: javascript java js 前端 浏览器 session 后端 sessionstorage

发布评论 0条评论)

还木有评论哦,快来抢沙发吧~