zoukankan      html  css  js  c++  java
  • HTML5-本地存储与cookies

    一、H5的几种存储形式

    1、本地存储(localstorage和sessionstorage)

    存储形式:key-->value

    过期策略:localstorage永久存储,不过期,除非手动删除,sessionstorage在重启浏览器、关闭页面或新开页面时失效

    大小限制:每个域名5M

    使用方法:(localstorage与sessionstorage操作相同)

    getItem(读取)、setItem(设置)、removeItem(移除)、key(索引)、clear(清空)

    存储内容:数组、json、图片、脚本、样式等可以序列化为字符串的内容

    //自定义localstorage的过期逻辑
    function set(key,val){
        var curTime=new Date().getTime();
        localStorage.setItem(key,JSON.stringify({data:val,time:curTime}))
    }
    function get(key,exp){
        var data=localStorage.getItem(key);
        var dataObj=JSON.parse(data);
        if(new Date().getTime()-dataObj.time>exp){
            console.log("已过期")
        }else{
            console.log("data="+dataObj.data)
        }
    }

    使用场景:利用本地数据,减少网络传输,弱网高延迟低带宽,尽量数据本地化

    2、离线存储(application cache)

    3、IndexedDB和Web SQL

    二、H5之前

    1、cookies

    优点:几乎所有浏览器都兼容;缺点:是每次请求头信息会带上;大小限制为4k;主Domain污染

    它的属性包括如下

    value  //键值对,如test=hello
    expires //绝对过期时间,如new Date(),所以浏览器都支持
    domain  //限定域名,如www.abc.com
    path    //限定路径,如/index
    max-age //相对失效时间,单位为秒;取代expires,冲突则以max-age为准(IE不支持)
    secure  //协议,不需要指定,当HTTPS通信时自动打开
    HttpOnly//仅用于服务器发送,JS无法读取
    
    document.cookie='test=hello;expires='+new Date(2017,5,1)+';path=/index;domain=www.abc.com;max-age=60*60*24*365;'
    //设置固定过期时间的cookies
    function setCookie(name,value){
        var Days = 30;
        var exp = new Date();
        exp.setTime(exp.getTime() + Days*24*60*60*1000);
        document.cookie = name + "="+ escape (value) + ";expires=" + exp.toGMTString();
    }
    //设置自定义过期时间cookie
    function setCookie(name,value,time){
        var msec = getMsec(time); //获取毫秒
        var exp = new Date();
        exp.setTime(exp.getTime() + msec*1);
        document.cookie = name + "="+ escape (value) + ";expires=" + exp.toGMTString();
    }
    //将字符串时间转换为毫秒,1秒=1000毫秒
    function getMsec(DateStr){
       var timeNum=str.substring(0,str.length-1)*1; //时间数量
       var timeStr=str.substring(str.length-1,str.length); //时间单位前缀,如h表示小时
       if (timeStr=="s"){ //20s表示20秒
            return timeNum*1000;}
       else if (timeStr=="h"){ //12h表示12小时
           return timeNum*60*60*1000;}
       else if (timeStr=="d"){
           return timeNum*24*60*60*1000;} //30d表示30天
    }
    //读取cookies
    function getCookie(name){
        var arr,reg=new RegExp("(^| )"+name+"=([^;]*)(;|$)"); //正则匹配
        if(arr=document.cookie.match(reg)){
          return unescape(arr[2]);
        }
        else{
         return null;
        }
    } 
    //删除cookies
    function delCookie(name){
        var exp = new Date();
        exp.setTime(exp.getTime() - 1);
        var cval=getCookie(name);
        if(cval!=null){
          document.cookie= name + "="+cval+";expires="+exp.toGMTString();
        }
    } 

    2、UserData:(仅IE)

  • 相关阅读:
    Commonjs,AMD,CMD和UMD的差异
    ajax中datatype的json和jsonp
    bufferd对象详解
    NodeJS中Buffer模块详解
    Vue 定义组件模板的七种方式(一般用单文件组件更好)
    vuejs 单文件组件.vue 文件
    git clone 带用户名密码
    去掉一组整型数组重复的值
    Vue中在组件销毁时清除定时器(setInterval)
    使用Nginx实现反向代理
  • 原文地址:https://www.cnblogs.com/gulei/p/6093701.html
Copyright © 2011-2022 走看看