HOW - localstorage 超时管理方案

文章目录

localStorage 本身 不支持过期时间(超时设置) ,因为它设计上是永久存储 (除非用户手动清除或调用 removeItem())。

不过,我们可以通过在存储时附带时间戳的方式,自行实现"超时机制"。


实现思路

当你调用 localStorage.setItem() 时,不直接存原始值,而是存一个带有时间戳的对象,例如:

js 复制代码
{
  value: "存储的数据",
  expire: 过期时间戳(单位:毫秒)
}

然后在读取时判断是否过期,如果过期则自动清除并返回 null


示例代码

封装工具函数

js 复制代码
/**
 * 设置带过期时间的 localStorage
 * @param {string} key 键名
 * @param {any} value 值
 * @param {number} expire 过期时间(毫秒)
 */
function setLocalStorage(key, value, expire) {
  const data = {
    value,
    expire: Date.now() + expire, // 当前时间 + 有效期
  };
  localStorage.setItem(key, JSON.stringify(data));
}

/**
 * 获取带过期判断的 localStorage
 * @param {string} key 键名
 * @returns {any | null} 值(若过期或不存在则返回 null)
 */
function getLocalStorage(key) {
  const raw = localStorage.getItem(key);
  if (!raw) return null;

  try {
    const data = JSON.parse(raw);
    if (data.expire && Date.now() > data.expire) {
      localStorage.removeItem(key); // 已过期,删除
      return null;
    }
    return data.value;
  } catch {
    return null;
  }
}

/**
 * 删除 localStorage
 */
function removeLocalStorage(key) {
  localStorage.removeItem(key);
}

使用示例

js 复制代码
// 存储 10 分钟有效的数据
setLocalStorage("userInfo", { name: "Tom" }, 10 * 60 * 1000);

// 读取数据
const user = getLocalStorage("userInfo");
if (user) {
  console.log("还没过期:", user);
} else {
  console.log("数据已过期或不存在");
}

补充建议

场景 建议
页面刷新频繁但不希望长期保存数据 sessionStorage
想要真正的过期机制(浏览器自动清理) 考虑 IndexedDB + 定时任务 或 后端 token 管控
想统一管理缓存 可以封装一个缓存工具类或用第三方库(如 store.js
相关推荐
鱼锦0.012 分钟前
基于spring+vue把图片文件上传至阿里云oss容器并回显
java·vue.js·spring
SoaringHeart15 分钟前
Flutter组件封装:标签拖拽排序 NDragSortWrap
前端·flutter
zeijiershuai17 分钟前
Vue 工程化、ElementPlus 快速入门、ElementPlus 常见组件-表格组件、ElementPlus常见组件-分页条组件
前端·javascript·vue.js
漫天黄叶远飞37 分钟前
把原型链画成地铁图:坐 3 站路就能看懂 JS 的“继承”怎么跑
前端·javascript
bank_dreamer40 分钟前
VSCODE前端代码风格格式化
前端·css·vscode·html·js·prettier·代码格式化
人工智能训练44 分钟前
前端框架选型破局指南:Vue、React、Next.js 从差异到落地全解析
运维·javascript·人工智能·前端框架·vue·react·next.js
IT_陈寒1 小时前
90%的Python开发者不知道:这5个内置函数让你的代码效率提升300%
前端·人工智能·后端
网络点点滴1 小时前
Vue3的生命周期
前端·javascript·vue.js
梵得儿SHI1 小时前
Vue 核心语法之组件基础与通信:从创建到注册的完整指南
前端·javascript·vue.js·组件化开发·全局注册·vue组件的本质·局部注册和异步组件