美文网首页
本地存储

本地存储

作者: neekoo | 来源:发表于2018-09-12 16:30 被阅读0次

前端开发的时候,在网页刷新的时候,所有数据都会被清空,这时候就要用到本地存储的技术,前端本地存储的方式有三种,分别是cookie,localStorage和sessionStorage 。

localStorage与sessionStorage

localStorage和sessionStorage,存在于window对象中:localStorage对应window.localStorage,sessionStorage对应window.sessionStorage。localStorage和sessionStorage的区别主要是在于其生存期。

如何调试

在chrome开发者工具里的application里,可以看到当前域名下的localstorage,sessionStorage,cookie数据。


企业微信截图_20180912155630.png

基本使用方法:

// 写入方法
localStorage.a = 1;
localStorage.setItem('b', '2'); // 推荐用法
localStorage['c'] = 3

// 读取方法
localStorage.a;
localStorage.getItem('a'); //推荐用法
localStorage['a'];
localStorage.key(0); // 获取第0个数据项的键名

//删除方法
localStorage.removeItem("a"); // 删除单个键值对
localStorage.clear(); // 清除当前域名下的所有localstorage数据

数据结构

sessionStorage和localStorage只支持string类型的存储,为标准的键值对数据类型,简单但也易扩展,只要以某种编码方式把想要存储进localstorage的对象给转化成字符串,就能轻松支持。举点例子:把对象转换成json字符串,就能让存储对象了;把图片转换成DataUrl(base64),就可以存储图片了。另外对于键值对数据类型来说,“键是唯一的”这个特性也是相当重要的,重复以同一个键来赋值的话,会覆盖上次的值。

let data = {
  name: 'neekoo',
  gender: 'male',
  hobby: 'female',
}
localStorage.setItem('data', JSON.stringify(data)); // 序列化
let obj = {};
obj = JSON.parse(localStorage.getItem('data')); //这时候需要反序列化一下

作用域

image.png
  • 这里的作用域指的是:如何隔离开不同页面之间的localStorage。
  • localStorage只要在相同的协议、相同的主机名、相同的端口下,就能读取/修改到同一份localStorage数据。
  • sessionStorage比localStorage更严苛一点,除了协议、主机名、端口外,还要求在同一窗口(也就是浏览器的标签页)下。

生存期

localStorage理论上来说是永久有效的,即不主动清空的话就不会消失,即使保存的数据超出了浏览器所规定的大小,也不会把旧数据清空而只会报错。
但需要注意的是,在移动设备上的浏览器或各Native App用到的WebView里,localStorage都是不可靠的,可能会因为各种原因(比如说退出App、网络切换、内存不足等原因)被清空。
sessionStorage的生存期顾名思义,类似于session,只要关闭浏览器(也包括浏览器的标签页),就会被清空。由于sessionStorage的生存期太短,因此应用场景很有限,但从另一方面来看,不容易出现异常情况,比较可靠。

容量限制

目前统一为5M,cookie为4K。

相关文章

  • localStorage和sessionStorage

    *示例 localStorage 设置本地存储 读取本地存储 清除本地存储 key()方法 说明:在不知道本地存储...

  • HTML 本地存储

    HTML本地存储:优于cookies 什么是HTML本地存储? 通过本地存储(Local Storage),web...

  • HTML5存储

    HTML5的本地存储与离线存储 1.本地存储 - Web storage2.本地存储 - indexedDB3...

  • iOS安全编码规范

    一.本地数据安全规范 1.本地存储密码、敏感数据加密: 本地存储:NSUserDefaults存储、plist文件...

  • H5存储

    1.本地存储-Web Storage2.本地存储-IndexedDB3.本地存储的扩展介绍4.离线存储-app c...

  • 本地存储和jQuery UI

    本地存储 本地存储分为cookie,以及新增的localStorage和sessionStoragecookie ...

  • Day 20 存储

    本地存储 本地存储分为cookie,以及H5新增的localStorage和sessionStorage; 本地储...

  • jQuery本地存储

    jQuery本地存储 本地存储有三种: cookie cookie 存储在本地,容量最大4k,在同源的http请求...

  • HTML本地存储

      本地存储:通过本地存储(Local Storage),web 应用程序能够在用户浏览器中对数据进行本地的存储。...

  • 本地存储

    本地存储 1 sessionStorage 会话存储 浏览器一关闭 就不存在 2 localS...

网友评论

      本文标题:本地存储

      本文链接:https://www.haomeiwen.com/subject/wkovgftx.html