通过JavaScript本地存储数据


本地存储

  • 数据存储在用户浏览器中
  • 设置、读取方便、甚至页面刷新都不丢失数据
  • 容量较大,sessionStorage和localStorage约5M左右

本地存储分类 - localStorage

可以将数据永久存储在本地(用户的电脑),除非手动删除,否则关闭页面也会存在。

特性:

  • 可以多窗口(页面)共享(同一浏览器可以共享)
  • 以键值对的形式存储使用

语法:

  • 存储/修改数据:localStorage.setltem(key,value) // 有改无增
  • 获取数据:localStorage.getItem(key)
  • 删除数据:localStorage.removeItem(key)

本地存储只能存储字符串类型,非字符串类型会转换成字符串类型存储

本地存储分类 - sessionStorage

特性:

  • 生命周期为关闭浏览器窗口
  • 在同一个窗口(页面)下数据可以共享
  • 以键值对的形式存储使用
  • 用法跟localStorage相同

存储复杂数据类型

本地只能存储字符串,无法存储复杂数据类型。

解决方法

需要将复杂数据类型转换成JSON字符串,再存储到本地。

语法:JSON.stringify(复杂数据类型)

保存时将对象转为JSON字符串:

    const obj = {
      uname: 'lily',
      age: 19,
      gender: '女'
    }
    localStorage.setItem('obj', JSON.stringify(obj))
    console.log(typeof localStorage.getItem('obj')) // 返回String,obj存进去是字符串,不是对象
    // JSON对象的属性和值都有引号,而且统一是双引号

取用时把JSON字符串转换为对象:JSON.parse(localStorage.getItem('obj'))


  • 6
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值