首页 > web前端 > js教程 > 正文

Web Storage使用指南_localStorage与sessionStorage的区别

幻影之瞳
发布: 2025-12-02 10:29:02
原创
170人浏览过
localStorage持久存储且同源共享,适合用户偏好;sessionStorage仅限当前会话,适合临时数据;两者均遵循同源策略,API相同但作用域与生命周期不同。

web storage使用指南_localstorage与sessionstorage的区别

在现代Web开发中,客户端数据存储是提升用户体验的重要手段。Web Storage API 提供了简单易用的机制,让开发者可以在浏览器中保存键值对数据。其中最常用的两种方式是 localStoragesessionStorage。虽然它们用法相似,但用途和生命周期有本质区别

1. 数据生命周期不同

localStorage 中的数据没有过期时间,除非手动清除,否则会一直保留在浏览器中,即使关闭标签页、重启浏览器或电脑也不会丢失。

sessionStorage 的数据仅在当前会话期间有效。一旦用户关闭页面或标签页,数据就会被自动清除。刷新页面不会影响 sessionStorage 中的内容。

  • localStorage:适合长期保存用户偏好设置(如主题、语言)
  • sessionStorage:适合临时保存表单数据或页面状态

2. 作用域范围不同

两者都遵循同源策略,即只有在协议、域名和端口完全一致的情况下才能访问相同的数据。

区别在于:

  • localStorage 在同源的所有页面之间共享。比如在一个标签页中写入 localStorage,在另一个同源标签页中也能读取到
  • sessionStorage 仅限于当前页面会话,即使是同源的其他标签页也无法访问该页面的 sessionStorage

3. 常用操作方法一致

localStorage 和 sessionStorage 都提供相同的API接口,使用方式完全一样:

Replit Ghostwrite
Replit Ghostwrite

一种基于 ML 的工具,可提供代码完成、生成、转换和编辑器内搜索功能。

Replit Ghostwrite 93
查看详情 Replit Ghostwrite
  • setItem(key, value):存储数据
  • getItem(key):读取数据
  • removeItem(key):删除某条数据
  • clear():清空所有数据
  • key(index):获取某个索引位置的键名

示例代码:

let userData = { name: 'Alice', age: 28 };
// 存储对象需转换为字符串
localStorage.setItem('user', JSON.stringify(userData));
sessionStorage.setItem('tempStep', '2');

// 读取数据
let savedUser = JSON.parse(localStorage.getItem('user'));
let currentStep = sessionStorage.getItem('tempStep');

4. 容量与限制

两者通常都有约5-10MB的存储空间(具体取决于浏览器),远大于Cookie的4KB限制。

注意点:

  • 只能存储字符串类型,存对象需要先用 JSON.stringify() 转换
  • 无法直接存储函数、undefined 或 Symbol 类型
  • 不支持监听复杂数据结构的变化
  • 运行在主线程,大量读写可能影响性能

基本上就这些。选择用哪个,关键看数据需要保留多久以及是否需要跨标签页共享。localStorage 适合持久化存储,sessionStorage 更适合临时会话场景。不复杂但容易忽略细节。

以上就是Web Storage使用指南_localStorage与sessionStorage的区别的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号