【localStorage的理解与使用】

1. 什么是localStorage?

localStorage是HTML5提供的一种在客户端存储数据的机制,可将数据存储在本地浏览器中,即使用户关闭了浏览器也不会丢失该数据。

2. localStorage可以用来做什么?

  • 数据共享:可以实现不同页面之间共享数据,例如一个页面存储了某个数据,另一个页面可以通过localStorage来获取这个数据。
  • 用户偏好设置:可以使用localStorage存储用户的偏好,例如语言偏好、主体选择,下次访问网站可以保留用户的个性化设置。
  • 会话保持状态:localStorage可以用来存储客户端用户的会话状态,例如登录状态、购物车内容,这样即使用户关闭了浏览器,再次打开也可以回到之前的状态。
  • 本地缓存:localStorage可以用来缓存数据,例如图片、脚本,这样可减少网络请求,提高页面加载速度。

注意:localStorage存储的数据是在客户端,不适合存储敏感信息,如密码。

3. localStorage常用方法

(1)存储数据,如下:key是自定义的数据键名,value是需要存储的实际值

javascript 复制代码
localStorage.setItem(key, value);

例如:login.html中将用户名为"Nancy"用localStorage存储在浏览器中

javascript 复制代码
localStorage.setItem('username', 'Nancy');

(2)获取数据,如下:key是之前设置的数据键名

javascript 复制代码
var 变量名 = localStorage.getItem(key);

例如:在index.html获取login.html中存储在浏览器中的用户名

javascript 复制代码
var name = localStorage.getItem('username');
console.log('在index.html中获取login.html存储在浏览器中的username=' + name);

(3)删除数据,其中key是要删除的数据键名

javascript 复制代码
localStorage.removeItem(key);

例如:退出登录时,将login.html存储在浏览器的username删除

javascript 复制代码
localStorage.removeItem('username');

4. 清空数据,用以清空浏览器存储的所有数据

javascript 复制代码
localStorage.clear();

注意点:

  1. localStorage存储的数据类型只能是字符串类型,如果要存储其他类型的数据,需要先转化为字符串类型,然后获取数据时,再将之转换为对应的类型
javascript 复制代码
var obj = {name:'Nancy', age:18};
localStorage.setItem('user', JSON.stringify(obj));   //转换为字符串再存储

--------------------------------------------------------
var userStr = localStorage.getIem('user');
var user = JSON.parse(userStr);  //将字符串类型转换为对应的类型
console.log(user.name);
console.log(user.age);
  1. localStorage存储的数据大小是有限制的,不同浏览器限制大小也不同,如果存储的数据查过了限制大小,会导致存储失败。
相关推荐
wuyijysx21 分钟前
JavaScript grammar
前端·javascript
学渣y2 小时前
React状态管理-对state进行保留和重置
javascript·react.js·ecmascript
_龙衣3 小时前
将 swagger 接口导入 apifox 查看及调试
前端·javascript·css·vue.js·css3
struggle20254 小时前
continue通过我们的开源 IDE 扩展和模型、规则、提示、文档和其他构建块中心,创建、共享和使用自定义 AI 代码助手
javascript·ide·python·typescript·开源
x-cmd4 小时前
[250512] Node.js 24 发布:ClangCL 构建,升级 V8 引擎、集成 npm 11
前端·javascript·windows·npm·node.js
夏之小星星4 小时前
el-tree结合checkbox实现数据回显
前端·javascript·vue.js
为美好的生活献上中指6 小时前
java每日精进 5.11【WebSocket】
java·javascript·css·网络·sql·websocket·网络协议
拖孩7 小时前
【Nova UI】十五、打造组件库之滚动条组件(上):滚动条组件的起步与进阶
前端·javascript·css·vue.js·ui组件库
苹果电脑的鑫鑫8 小时前
element中表格文字剧中可以使用的属性
javascript·vue.js·elementui
一丝晨光8 小时前
数值溢出保护?数值溢出应该是多少?Swift如何让整数计算溢出不抛出异常?类型最大值和最小值?
java·javascript·c++·rust·go·c·swift