登录
首页 >  文章 >  前端

localStorage与sessionStorage区别解析

时间:2025-12-15 13:21:37 328浏览 收藏

推广推荐
免费电影APP ➜
支持 PC / 移动端,安全直达

哈喽!今天心血来潮给大家带来了《JavaScript本地存储:localStorage与sessionStorage区别详解》,想必大家应该对文章都不陌生吧,那么阅读本文就都不会很困难,以下内容主要涉及到,若是你正在学习文章,千万别错过这篇文章~希望能帮助到你!

localStorage永久保存数据,sessionStorage仅在当前标签页会话有效;前者适合用户偏好等跨会话信息,后者适合表单草稿等临时数据;均受同源限制且仅支持字符串,禁存敏感信息。

如何使用JavaScript实现本地存储_localStorage和sessionStorage有什么区别呢

localStorage 和 sessionStorage 都是浏览器提供的本地存储 API,用来在用户设备上保存键值对数据,但它们的生命周期和作用域不同——简单说:localStorage 永久保存(除非手动清除),sessionStorage 只在当前标签页会话期间有效

localStorage:关掉浏览器也不丢数据

适合存用户偏好、主题设置、登录态标识等需要跨会话保留的信息。数据不会因页面刷新、关闭标签页甚至重启浏览器而丢失,只有以下情况才会被清除:用户主动清理浏览器缓存、调用 localStorage.clear() 或通过 localStorage.removeItem(key) 删除指定项。

  • 写入: localStorage.setItem('theme', 'dark')
  • 读取: localStorage.getItem('theme') → 返回 "dark"
  • 删除: localStorage.removeItem('theme')
  • 清空全部: localStorage.clear()

sessionStorage:只活在当前标签页里

数据仅在单个浏览器标签页(或窗口)中有效,关闭该标签页后自动销毁。适合临时缓存表单草稿、导航状态、一次性验证码等不需长期保留的内容。新开一个相同 URL 的标签页,sessionStorage 是完全独立的。

  • 写入: sessionStorage.setItem('draft', 'hello world')
  • 读取: sessionStorage.getItem('draft')
  • 注意:刷新页面不会清空,但关闭标签页就没了

关键区别总结

作用域:两者都按协议+域名+端口划分(即同源限制),但 sessionStorage 还多一层“标签页隔离”;有效期:localStorage 是持久化,sessionStorage 是会话级;容量限制:通常都是 5MB 左右(具体看浏览器),超出会抛错;数据类型:只支持字符串,存对象要先 JSON.stringify(),读取时再 JSON.parse()

小提醒:别存敏感信息

它们都运行在前端,任何脚本都能读写,所以不要存密码、token、银行卡号等敏感内容。如果必须暂存 token,建议配合 HttpOnly Cookie + 后端校验,而不是全靠 localStorage。

基本上就这些。用对场景,比用得多更重要。

今天关于《localStorage与sessionStorage区别解析》的内容介绍就到此结束,如果有什么疑问或者建议,可以在golang学习网公众号下多多回复交流;文中若有不正之处,也希望回复留言以告知!

相关阅读
更多>
最新阅读
更多>
课程推荐
更多>