localStorage是JavaScript本地存储中最常用的方式,提供持久化键值对存储且数据在浏览器关闭后仍保留;它属于Web Storage API,仅支持字符串、容量约5–10MB、同域隔离,需用setItem()/getItem()/removeItem()等方法操作,并避免存储敏感信息。
JavaScript本地存储指的是网页在用户浏览器中保存数据的能力,不依赖服务器,数据保留在用户设备上。其中 localStorage 是最常用的一种,它提供简单、持久的键值对存储,关闭浏览器甚至重启电脑后数据依然存在。
localStorage 是 Web Storage API 的一部分,每个域名有独立的存储空间(通常约 5–10MB),只支持字符串类型的数据。它和 sessionStorage 的区别在于:localStorage 没有过期时间,除非手动清除,否则一直保留;而 sessionStorage 只在当前标签页生命周期内有效。
使用 setItem() 方法存入数据,两个参数:键名(字符串)和键值(也必须是字符串)。
localStorage.setItem('username', 'Alice');
localStorage.setItem('cart', JSON.stringify([{id: 1, name: 'book'}]));
读取用 getItem(),删除用 removeItem() 或清空全部用 clear()。
const name = localStorage.getItem('username');(返回 null 如果不存在)const cart = JSON.parse(localStorage.getItem('cart') || '[]');
setItem() 同一键名会自动覆盖旧值localStorage.removeItem('tempToken');
localStorage.clear();(慎用,会影响同域下所有 localStorage 数据)localStorage 不是万能的,有些情况它并不适用:
storage 事件在其他同域窗口中响应(当前窗口修改不会触发自身事件)基本上就这些。用好 localStorage 能显著提升用户体验,比如记住表单输入、缓存配置、暂存购物车等,关键是要理解它的边界和限制。