前端开发的时候,在网页刷新的时候,所有数据都会被清空,这时候就要用到本地存储的技术,前端本地存储的方式有三种,分别是cookie,localStorage和sessionStorage 。
localStorage与sessionStorage
localStorage和sessionStorage,存在于window对象中:localStorage对应window.localStorage,sessionStorage对应window.sessionStorage。localStorage和sessionStorage的区别主要是在于其生存期。
如何调试
在chrome开发者工具里的application里,可以看到当前域名下的localstorage,sessionStorage,cookie数据。
基本使用方法:
// 写入方法
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')); //这时候需要反序列化一下
作用域
- 这里的作用域指的是:如何隔离开不同页面之间的localStorage。
- localStorage只要在相同的协议、相同的主机名、相同的端口下,就能读取/修改到同一份localStorage数据。
- sessionStorage比localStorage更严苛一点,除了协议、主机名、端口外,还要求在同一窗口(也就是浏览器的标签页)下。
生存期
localStorage理论上来说是永久有效的,即不主动清空的话就不会消失,即使保存的数据超出了浏览器所规定的大小,也不会把旧数据清空而只会报错。
但需要注意的是,在移动设备上的浏览器或各Native App用到的WebView里,localStorage都是不可靠的,可能会因为各种原因(比如说退出App、网络切换、内存不足等原因)被清空。
sessionStorage的生存期顾名思义,类似于session,只要关闭浏览器(也包括浏览器的标签页),就会被清空。由于sessionStorage的生存期太短,因此应用场景很有限,但从另一方面来看,不容易出现异常情况,比较可靠。
容量限制
目前统一为5M,cookie为4K。