【JavaScript】localStorage

1. 什么是 localStorage

localStorage 是一个 JavaScript API,允许在浏览器中存储键值对数据。它提供了一个简单的持久性存储方案,数据保存在用户的本地浏览器中,并且在页面刷新或关闭后依然存在。它只能存储字符串类型的数据。

无痕模式下,关闭浏览器,localStorage 中存储的数据也会被清空。

2. 如何使用 localStorage

javascript 复制代码
// 存储数据
localStorage.setItem('key', 'value');

// 获取数据
const value = localStorage.getItem('key');

// 删除数据
localStorage.removeItem('key');

// 清空所有数据
localStorage.clear();
js 复制代码
console.log(localStorage,sessionStorage)
let color = {
    "c1": "red",
    "c2": "green"
}
// 存储时 都会先转为 string 所以我们如果想要存储复杂类型 需要转 json
localStorage.setItem('color', JSON.stringify(color))
console.log(JSON.parse(localStorage.getItem('color')))

3. localStorage 的容量限制是多少?

每个域名下的 localStorage 都有一定的存储容量限制,通常在 5MB 左右(远大于 cookie 的 4kb)。这个限制是浏览器实现的,不同浏览器可能有略微不同的限制。如果超过了这个限制,浏览器可能会提示用户清理缓存或拒绝继续写入数据(不同浏览器有相应的不同策略)。

4. localStoragesessionStorage 有什么区别?

localStoragesessionStorage 都属于 Web Storage API,但它们有一些关键区别:

  • localStorage 中存储的数据在页面关闭后依然存在,而 sessionStorage 中存储的数据在会话结束(页面关闭)后被清除。
  • localStorage 中的数据可以在同一域名下的任何页面间共享,而 sessionStorage 中的数据只能在同一页面的不同窗口或标签页间共享。
相关推荐
默_笙1 小时前
🛬 我让 AI 帮我写了一个打飞机游戏,结果 Canvas 把我整不会了
前端·javascript
梯度不陡1 小时前
AI 到底能不能从零写软件?ProgramBench 和 RepoZero 给出了两种答案
前端·javascript·面试
胡萝卜术3 小时前
滑动窗口最大值:从暴力到单调队列,层层优化全解析
前端·javascript·面试
kyriewen4 小时前
2026 年了,这 6 个 npm 包可以卸载了——浏览器原生 API 已经能替代
前端·javascript·npm
铁皮饭盒5 小时前
bun直接tsx,优雅!
javascript·后端
_柳青杨7 小时前
一文吃透 Node.js 事件循环:从原理到 Node 20+ 重大变更
javascript·后端
JieE21218 小时前
LeetCode 101. 对称二叉树|JS 递归 + 迭代双解法,彻底搞懂镜像判断
javascript·算法
冬奇Lab20 小时前
AI Workflow 定义的四次演进:从 Markdown 到 JS 脚本,再到分布式多 Agent
javascript·人工智能·agent
一颗烂土豆1 天前
Meshopt 压缩深度解析,为什么它比 Draco 更快
前端·javascript·webgl
kyriewen1 天前
同事每天催我 Code Review,我写了个脚本让 AI 替我 review PR——现在他反过来催 AI 了
前端·javascript·ai编程