localStorage长期存储、跨会话共享,sessionStorage仅限当前标签页会话;二者均同源隔离、仅存字符串、API相同,但生命周期与作用域不同。
JavaScript 中的 localStorage 和 sessionStorage 都是浏览器提供的 Web Storage API,用于在客户端存储键值对数据,但它们的生命周期、作用域和使用场景有本质区别。
数据一旦写入,会一直保留在浏览器中,除非被代码主动删除或用户手动清除缓存。它不随页面关闭、标签页关闭或浏览器重启而消失,适合存储需要持久化的内容,比如用户偏好设置、主题选择、登录态标识(注意:敏感信息如 token 不建议明文存这里)。
JSON.stringify(),读取时用 JSON.parse()
数据只在当前浏览器标签页(或窗口)的会话周期内有效。关闭该标签页后,数据自动清空;新开一个相同 URL 的标签页,也会拥有独立的 sessionStorage。适合临时状态管理,比如表单草稿、导航参数、多步骤流程中的中间数据。
两者 API 完全相同,都提供 setItem(key, value)、getItem(key)、r 和
emoveItem(key)clear() 方法:
// 存储
localStorage.setItem('theme', 'dark');
sessionStorage.setItem('formDraft', JSON.stringify({ name: 'Alice', email: 'a@b.c' }));
// 读取
const theme = localStorage.getItem('theme'); // 'dark'
const draft = JSON.parse(sessionStorage.getItem('formDraft')); // { name: 'Alice', ... }
// 删除
localStorage.removeItem('theme');
sessionStorage.clear(); // 清空当前会话所有数据
两者都运行在前端,数据可被用户直接查看和修改,绝不能用于存储密码、token、银行卡号等敏感信息。若需临时存 token,优先考虑 httpOnly Cookie;若必须用 Storage,请配合后端校验与短期有效期控制。
另外,Storage 是同步阻塞操作,在大量数据读写时可能影响主线程性能,高频场景建议节流或改用 IndexedDB。