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. localStorage
与 sessionStorage
有什么区别?
localStorage
与 sessionStorage
都属于 Web Storage API,但它们有一些关键区别:
localStorage
中存储的数据在页面关闭后依然存在,而sessionStorage
中存储的数据在会话结束(页面关闭)后被清除。localStorage
中的数据可以在同一域名下的任何页面间共享,而sessionStorage
中的数据只能在同一页面的不同窗口或标签页间共享。