【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存储的数据大小是有限制的,不同浏览器限制大小也不同,如果存储的数据查过了限制大小,会导致存储失败。
相关推荐
前端小趴菜052 小时前
React-React.memo-props比较机制
前端·javascript·react.js
RadiumAg4 小时前
记一道有趣的面试题
前端·javascript
yangzhi_emo4 小时前
ES6笔记2
开发语言·前端·javascript
yanlele5 小时前
我用爬虫抓取了 25 年 5 月掘金热门面试文章
前端·javascript·面试
烛阴6 小时前
void 0 的奥秘:解锁 JavaScript 中 undefined 的正确打开方式
前端·javascript
初遇你时动了情6 小时前
腾讯地图 vue3 使用 封装 地图组件
javascript·vue.js·腾讯地图
dssxyz6 小时前
uniapp打包微信小程序主包过大问题_uniapp 微信小程序时主包太大和vendor.js过大
javascript·微信小程序·uni-app
ohMyGod_1239 小时前
React16,17,18,19新特性更新对比
前端·javascript·react.js
@大迁世界9 小时前
第1章 React组件开发基础
前端·javascript·react.js·前端框架·ecmascript
一瓣橙子9 小时前
7.7日 实验03-Spark批处理开发(2)
开发语言·javascript·ajax