LocalStorage和SessionStorage使用教程
目前golang学习网上已经有很多关于文章的文章了,自己在初次阅读这些文章中,也见识到了很多学习思路;那么本文《LocalStorage与SessionStorage怎么用?》,也希望能帮助到大家,如果阅读完后真的对你学习文章有帮助,欢迎动动手指,评论留言并分享~
答案:LocalStorage用于持久化存储,数据跨会话保留,适合长期配置;SessionStorage限于当前会话,关闭标签页即清除,适用于临时状态传递。两者均遵循同源策略,仅支持字符串存储,需注意安全与性能问题。
前端缓存,特别是LocalStorage和SessionStorage,本质上是浏览器提供给开发者在客户端存储键值对数据的两种机制。它们最大的区别在于数据的生命周期和作用域:LocalStorage数据持久化,除非手动清除,否则一直存在;SessionStorage则随着浏览器会话的结束而清除。选择哪一个,往往取决于你的数据需要“活”多久,以及在什么范围内共享。
当我们谈论前端缓存,LocalStorage和SessionStorage这对“双生子”总是绕不开的话题。它们都属于Web Storage API的一部分,提供了一种比Cookie更安全、更大容量(通常5MB或更多)的客户端存储方式。
LocalStorage的设计理念是持久化存储。这意味着一旦数据被写入LocalStorage,它就会一直存在于用户的浏览器中,即便用户关闭了浏览器,甚至重启电脑,数据依然在那里,直到你通过代码明确删除,或者用户手动清除浏览器缓存。这让它非常适合存储那些不经常变动、且需要长期保留的数据,比如用户的偏好设置(主题模式、语言选择)、用户的登录状态(记住我功能)、或者一些不敏感的静态配置信息。想象一下,你访问一个网站,下次再来,它依然记得你的主题偏好,这就是LocalStorage在默默工作。
SessionStorage则不同,它的生命周期与浏览器会话紧密相连。一个会话(session)通常指的是从用户打开浏览器标签页或窗口到关闭它的这段时间。这意味着,如果你在一个标签页中存储了数据到SessionStorage,然后关闭了这个标签页,数据就会被销毁。即使你在同一个浏览器中打开了另一个标签页,SessionStorage的数据也是独立的,不会共享。这种特性让SessionStorage成为存储临时性、会话级别数据的理想选择,比如用户在多步表单中的临时输入、页面间的状态传递(例如,从商品列表页跳转到详情页时携带的临时筛选条件),或者一些不希望在用户关闭页面后仍然存在的敏感数据。它就像一个临时的便签纸,用完即扔。
实际应用中,两者的选择往往基于数据敏感度和持久化需求。如果数据需要跨会话存在,且不涉及高度敏感信息,LocalStorage是首选。如果数据仅在当前会话有效,且关闭页面后应立即清除,SessionStorage则更合适。当然,我们也要警惕,无论是LocalStorage还是SessionStorage,存储的数据都是明文的,不适合直接存放用户的敏感信息如密码。安全起见,这类数据应该加密处理,或者仅存储令牌(Token),而非原始凭证。
何时选择LocalStorage而非SessionStorage?
这个问题其实指向了我们对数据生命周期和作用域的核心考量。选择LocalStorage,通常是出于对数据持久性的需求。
一个典型的场景是用户个性化设置。比如,一个内容网站允许用户选择深色模式或浅色模式,或者调整字体大小。这些设置一旦确定,用户会希望下次访问时依然生效,而不需要重新设置。将这些偏好存储在LocalStorage中,即使浏览器关闭再打开,这些设置也能被恢复。
再比如,“记住我”的登录状态。当然,这里通常存储的是一个不包含敏感信息的token,而非用户的明文账号密码。这个token需要跨会话保持,这样用户就无需每次都输入凭证。LocalStorage是实现这种长效登录体验的基石。
离线数据存储也是LocalStorage的一个重要应用。对于一些不经常变动但又需要快速访问的静态数据,比如一些配置项、字典数据,甚至是一些简单的用户生成内容(如果应用支持离线编辑),LocalStorage能提供一个快速的本地访问通道,减少对网络的依赖,提升用户体验。当网络恢复时,这些数据可以再同步到服务器。
购物车数据在某些场景下也可以考虑LocalStorage。如果用户将商品加入购物车后,即使关闭了浏览器,也希望下次打开时购物车内容还在,那么LocalStorage就能派上用场。但要注意,这通常是作为一种临时或辅助存储,最终的购物车状态仍需与后端同步,以确保数据一致性。
总之,当你需要数据在用户关闭浏览器后依然“活着”,并且在同一个域名下的所有窗口和标签页中都能访问时,LocalStorage就是你的不二之选。它提供了一种相对简单且高效的持久化存储方案,但切记,容量限制和安全性(明文存储)是使用时必须考虑的因素。
SessionStorage在多页应用中如何有效传递数据?
SessionStorage在多页应用中的数据传递,其核心优势在于它限定在单个浏览器会话的生命周期内,并且在同一域名下,不同的标签页或窗口拥有独立的SessionStorage实例。理解这一点至关重要。这意味着如果你在A标签页存了数据,B标签页是访问不到的。那么,它如何有效传递数据呢?
实际上,SessionStorage的这种隔离性,使得它在需要页面跳转时传递临时状态方面表现出色。例如,用户在一个表单的第一个页面填写了一些信息,点击“下一步”跳转到第二个页面。这些信息在第一个页面关闭后就不再需要,但又必须传递到第二个页面进行处理。这时,在第一个页面将数据存入SessionStorage,第二个页面加载时从SessionStorage中取出数据,处理完毕后可以立即清除。
考虑一个电商网站的结账流程。用户在购物车页面确认订单后,跳转到收货地址选择页面,再到支付页面。在这些页面之间,可能需要传递订单ID、商品列表摘要、优惠券信息等。这些数据在整个结账会话中是必要的,但一旦支付完成或者用户放弃支付关闭页面,这些数据就应该被清理。SessionStorage完美契合了这种临时性、流程化的数据传递需求。
另一个场景是用户操作的“回溯”。比如,用户在一个复杂的筛选页面进行了多项选择,跳转到结果页面。如果用户想回到筛选页面微调,我们希望他之前选择的条件依然存在。将筛选条件存储在SessionStorage中,当用户从结果页返回筛选页时,可以恢复这些条件,提升用户体验。
值得注意的是,SessionStorage的数据在同源的同一个标签页或窗口中是共享的。如果你通过window.open()
或者标签的
target="_blank"
打开新窗口,新窗口的SessionStorage会继承父窗口的数据副本。这提供了一种在特定场景下,跨窗口(但属于同一会话)传递数据的能力,但这种继承只发生在打开的瞬间,之后两个窗口的SessionStorage就独立了。
总结来说,SessionStorage在多页应用中的价值在于其会话级别的临时性和同源同标签页内的共享性。它是一个理想的“中转站”,用于在用户完成特定流程或任务期间,安全、高效地传递非持久化的状态信息。
LocalStorage与SessionStorage的常见陷阱与最佳实践是什么?
在使用LocalStorage和SessionStorage时,尽管它们提供了便利,但也存在一些不容忽视的陷阱,以及随之而来的最佳实践。
陷阱一:安全性问题 最常见的陷阱就是安全性。两者存储的数据都是明文的,并且可以通过JavaScript在客户端被轻易访问到。这意味着,如果你的网站存在XSS(跨站脚本攻击)漏洞,攻击者可以轻易地读取或修改LocalStorage和SessionStorage中的任何数据。因此,绝不能存储敏感信息,如用户的密码、银行卡号等。
- 最佳实践:
- 只存储非敏感数据:例如用户偏好、主题设置、不含隐私的配置信息。
- 加密敏感数据:如果确实需要存储一些与用户身份相关的标识(如认证令牌),务必对其进行加密或编码处理,并且只存储短生命周期的令牌,而非长期凭证。
- 避免XSS漏洞:这是前端安全的基石,也是保护Web Storage数据的前提。
陷阱二:容量限制与性能影响 虽然比Cookie容量大,但它们依然有容量限制(通常5-10MB)。如果存储过大的数据,可能会导致超出限制,或者在读写时造成性能问题,尤其是在低端设备上。
- 最佳实践:
- 精简存储内容:只存储必要的数据,避免存储冗余或可以通过后端API获取的数据。
- 定期清理:对于LocalStorage,考虑设计一个过期机制,定期清理不再需要的数据。
- 异步操作:对于大量数据的读写,考虑使用Web Workers进行异步操作,避免阻塞主线程。
陷阱三:数据类型限制 Web Storage只能存储字符串。这意味着如果你想存储对象或数组,必须先将其序列化为JSON字符串,读取时再反序列化。
最佳实践:
JSON.stringify() 和 JSON.parse():这是处理对象和数组的标准做法。
// 存储对象 const userSettings = { theme: 'dark', fontSize: 16 }; localStorage.setItem('settings', JSON.stringify(userSettings)); // 读取对象 const storedSettings = JSON.parse(localStorage.getItem('settings')); console.log(storedSettings.theme);
错误处理:在
JSON.parse()
时,最好进行try...catch
处理,以防存储的数据不是有效的JSON格式。
陷阱四:同源策略 Web Storage遵循同源策略,这意味着不同源(协议、域名、端口任一不同)的页面无法访问彼此的LocalStorage和SessionStorage。这通常是一个安全特性,但有时也会被误解为陷阱。
- 最佳实践:
- 明确作用域:清楚你的应用是否涉及跨域通信,如果是,Web Storage不是合适的跨域数据共享方案。考虑使用
postMessage
或其他后端服务。
- 明确作用域:清楚你的应用是否涉及跨域通信,如果是,Web Storage不是合适的跨域数据共享方案。考虑使用
陷阱五:过度依赖与数据一致性 过度依赖客户端存储,尤其是在需要与后端同步的场景,可能导致数据不一致。例如,用户在LocalStorage中修改了某个配置,但这个修改没有同步到后端,导致在其他设备上访问时配置不同步。
- 最佳实践:
- 明确数据归属:区分哪些数据是纯客户端偏好,哪些是需要与后端同步的核心业务数据。
- 同步机制:对于需要同步的数据,设计清晰的同步机制,例如在数据更新后立即调用API通知后端,或者在应用启动时从后端拉取最新数据。
- 版本控制:如果存储的配置数据可能随应用版本更新而改变结构,考虑在存储时加入版本号,以便在应用更新时进行兼容性处理或清理旧数据。
通过理解这些陷阱并采纳最佳实践,我们才能更安全、高效、负责任地利用LocalStorage和SessionStorage,真正发挥它们在前端缓存策略中的作用。
到这里,我们也就讲完了《LocalStorage和SessionStorage使用教程》的内容了。个人认为,基础知识的学习和巩固,是为了更好的将其运用到项目中,欢迎关注golang学习网公众号,带你了解更多关于的知识点!

- 上一篇
- Win10修改MAC地址方法详解

- 下一篇
- 学习通视频快速刷课方法
-
- 文章 · 前端 | 3分钟前 |
- Next.js13SVG动画与透明背景导入方案
- 403浏览 收藏
-
- 文章 · 前端 | 12分钟前 | CSS
- CSS瀑布流布局实现教程
- 444浏览 收藏
-
- 文章 · 前端 | 14分钟前 | 测试数据生成
- JavaScript迭代器与生成器简化测试用例生成
- 452浏览 收藏
-
- 文章 · 前端 | 15分钟前 |
- CSSOverflow属性详解与使用技巧
- 237浏览 收藏
-
- 文章 · 前端 | 19分钟前 | CSSGrid justify-self align-self 单元格对齐 单个网格项
- CSS中justify-self和align-self用法详解
- 150浏览 收藏
-
- 文章 · 前端 | 29分钟前 |
- 如何在HTML中打开新窗口?
- 109浏览 收藏
-
- 文章 · 前端 | 43分钟前 |
- HTML文件搜索技巧与工具推荐
- 327浏览 收藏
-
- 文章 · 前端 | 45分钟前 |
- Fixed定位结合transform性能优化技巧
- 275浏览 收藏
-
- 文章 · 前端 | 45分钟前 |
- ReactNative文本截断技巧详解
- 166浏览 收藏
-
- 文章 · 前端 | 49分钟前 |
- HTML5八大高级功能详解与学习指南
- 112浏览 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 499次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 484次学习
-
- PandaWiki开源知识库
- PandaWiki是一款AI大模型驱动的开源知识库搭建系统,助您快速构建产品/技术文档、FAQ、博客。提供AI创作、问答、搜索能力,支持富文本编辑、多格式导出,并可轻松集成与多来源内容导入。
- 362次使用
-
- AI Mermaid流程图
- SEO AI Mermaid 流程图工具:基于 Mermaid 语法,AI 辅助,自然语言生成流程图,提升可视化创作效率,适用于开发者、产品经理、教育工作者。
- 1145次使用
-
- 搜获客【笔记生成器】
- 搜获客笔记生成器,国内首个聚焦小红书医美垂类的AI文案工具。1500万爆款文案库,行业专属算法,助您高效创作合规、引流的医美笔记,提升运营效率,引爆小红书流量!
- 1178次使用
-
- iTerms
- iTerms是一款专业的一站式法律AI工作台,提供AI合同审查、AI合同起草及AI法律问答服务。通过智能问答、深度思考与联网检索,助您高效检索法律法规与司法判例,告别传统模板,实现合同一键起草与在线编辑,大幅提升法律事务处理效率。
- 1178次使用
-
- TokenPony
- TokenPony是讯盟科技旗下的AI大模型聚合API平台。通过统一接口接入DeepSeek、Kimi、Qwen等主流模型,支持1024K超长上下文,实现零配置、免部署、极速响应与高性价比的AI应用开发,助力专业用户轻松构建智能服务。
- 1249次使用
-
- 优化用户界面体验的秘密武器:CSS开发项目经验大揭秘
- 2023-11-03 501浏览
-
- 使用微信小程序实现图片轮播特效
- 2023-11-21 501浏览
-
- 解析sessionStorage的存储能力与限制
- 2024-01-11 501浏览
-
- 探索冒泡活动对于团队合作的推动力
- 2024-01-13 501浏览
-
- UI设计中为何选择绝对定位的智慧之道
- 2024-02-03 501浏览