美文网首页
本地存储

本地存储

作者: 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。

    相关文章

      网友评论

          本文标题:本地存储

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