登录
首页 >  文章 >  前端

localStorage与sessionStorage区别详解

时间:2025-12-26 15:45:41 411浏览 收藏

对于一个文章开发者来说,牢固扎实的基础是十分重要的,golang学习网就来带大家一点点的掌握基础知识点。今天本篇文章带大家了解《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学习网公众号!

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