zoukankan      html  css  js  c++  java
  • 三分钟快速了解 localStorage 与 sessionStorage及区别

    localstorage(本地存储)

    在这里插入图片描述

    优势

    • localStorage 拓展了 cookie 的 4K 限制。
    • localStorage 会可以将第一次请求的数据直接存储到本地,这个相当于一个 5M 大小的针对于前端页面的数据库,相比于 cookie 可以节约带宽,但是这个却是只有在高版本的浏览器中才支持的。
    • 不会传送到服务器,存储在本地的数据可以直接获取,减少了客户端和服务器端的交互,节省了网络流量

    局限

    • 浏览器的大小不统一,并且在 IE8 以上的 IE 版本才支持 localStorage 这个属性。
    • 目前所有的浏览器中都会把localStorage的值类型限定为string类型,这个在对我们日常比较常见的JSON对象类型需要一些转换。
    • localStorage在浏览器的隐私模式下面是不可读取的。
    • localStorage本质上是对字符串的读取,如果存储内容多的话会消耗内存空间,会导致页面变卡。
    • localStorage不能被爬虫抓取到。
    • 仅保存在客户端,不参与和服务器的通信
    • 数据对象没有过期时间,除非你手动去删除。

    存储对象属性

    属性 描述
    length 返回存储对象中包含多少条数据。

    存储对象方法

    方法 描述
    key(n) 返回存储对象中第 n 个键的名称
    getItem(keyname) 返回指定键的值
    setItem(keyname, value) 添加键和值,如果对应的值存在,则更新该键对应的值。
    removeItem(keyname) 移除键
    clear() 清除存储对象中所有的键

    首先在使用 localStorage 的时候,我们需要判断浏览器是否支持 localStorage 这个属性:

    if(!window.localStorage){
        alert("浏览器不支持localstorage");
    }else{
        alert("浏览器支持localstorage");
        //主逻辑业务
    }
    

    在这里插入图片描述

    三种方法写入

    if(!window.localStorage){
        alert("浏览器不支持localstorage");
    }else{
        var storage=window.localStorage;
        //写入方法一:a字段
        storage["a"]=1;
        //写入方法二:b字段
        storage.b=2;
        //写入方法三:c字段(官方提倡)
        storage.setItem("c",3);
        console.log(typeof storage["a"]);
        console.log(typeof storage.b);
        console.log(typeof storage["c"]);
    }
    

    在这里插入图片描述

    三种方法读取

    if(!window.localStorage){
        alert("浏览器不支持localstorage");
    }else{
        var storage=window.localStorage;
        storage["a"]=1;
        storage.a=2;
        storage.setItem("c",3);
        //第一种方法读取
        console.log(storage.a);//1
        //第二种方法读取
        console.log(storage["b"]);//2
        //第三种方法读取(官方提倡)
        console.log(storage.getItem("c"));//3
    }
    

    修改与写入一致,就是覆盖原来的数据

    删除

    1、将localStorage的所有内容清除

    var storage=window.localStorage;
    storage.a=1;
    storage.setItem("c",3);
    console.log(storage);
    storage.clear();
    console.log(storage);
    

    在这里插入图片描述

    2、 将 localStorage 中的某个键值对删除

    var storage=window.localStorage;
    storage.a=1;
    storage.setItem("c",3);  //设置
    console.log(storage);
    storage.removeItem("a"); //移除
    console.log(storage.a);  //undefined
    

    在这里插入图片描述

    键key的获取

    var storage=window.localStorage;
    storage.a=1;
    storage.setItem("c",3);
    for(var i=0;i<storage.length;i++){
        var key=storage.key(i);
        console.log(key);//a c
    }
    

    注意事项

    一般我们会将 JSON 存入 localStorage 中,但是在 localStorage 会自动将 localStorage 转换成为字符串形式。
    这个时候我们可以使用 JSON.stringify() 这个方法,来将 JSON 转换成为 JSON 字符串。读取之后要将 JSON 字符串转换成为 JSON 对象,使用 JSON.parse() 方法:

    var storage=window.localStorage;
    var data={
        name:'fur',
        sex:'girl',
        hobby:'code'
    };
    
    //将对象转换成json格式字符串
    var d=JSON.stringify(data);
    console.log(d)
    //{"name":"fur","sex":"girl","hobby":"code"}
    
    //将字符串存入data
    storage.setItem("data",d);
    
    //获取字符串形式的data
    var json=storage.getItem("data");
    
    //将JSON字符串转换成为JSON对象输出
    var jsonObj=JSON.parse(json);
    console.log(jsonObj)
    //Object { name: "fur", sex: "girl", hobby: "code" }
    console.log(typeof jsonObj);//object
    

    sessionStorage (会话存储)

    sessionStorage 用于临时保存同一窗口(或标签页)的数据,在关闭窗口或标签页之后将会删除这些数据,增删改查写法与localstorage一致,不在赘述。

    if(!window.sessionStorage ){
        alert("浏览器不支持sessionStorage ");
    }else{
        alert("浏览器支持sessionStorage ");
        //主逻辑业务
    }
    

    localStorage 与 sessionStorage 区别

    • localStorage 属于永久性存储,而 sessionStorage 属于当会话结束的时候,sessionStorage 中的键值对会被清空。

    • 不同浏览器无法共享localStorage或sessionStorage中的信息。同一浏览器的相同域名和端口的不同页面间可以共享相同的 localStorage,但是不同页面间无法共享sessionStorage的信息。

    • localStoragese:常用于长期登录(+判断用户是否已登录),适合长期保存在本地的数据,而sessionStorage:敏感账号一次性登录

  • 相关阅读:
    elasticsearch官方文档摸索
    nginx报错upstream sent invalid chunked response while reading upstream
    LRU算法的实现
    linux命令小计
    【阅读笔记】深入java虚拟机-第三部分-虚拟机执行子系统
    spring-session-data-redis导致跨域session失效
    ReentrantLock源码解读
    AbstractQueuedSynchronizer(AQS源码解读)
    Object中wait()、notify()、notifyAll()
    redis(单机模式)分布式锁的实现【已废弃】
  • 原文地址:https://www.cnblogs.com/furfur-jiang/p/12238715.html
Copyright © 2011-2022 走看看