前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >JavaScript中如何给localStorage设置一个有效期?

JavaScript中如何给localStorage设置一个有效期?

作者头像
Javanx
发布2019-09-04 10:24:33
1.9K0
发布2019-09-04 10:24:33
举报
文章被收录于专栏:web秀web秀

前言

从我们接触前端起,第一个熟悉的存储相关的Cookie或者来分析我们生活中密切相关的淘宝、物流、闹钟等事物来说起吧,

JavaScript中如何给localStorage设置一个有效期?
JavaScript中如何给localStorage设置一个有效期?
Cookie从你设置的时候,就会给个时间,不设置默认会话结束就过期;
淘宝购物 从你下单付款起,就会给这件货物设置一个收货期限时间,过了这个时间自动认为你收货(即订单结束);
闹钟 你设置的提醒时间,其实也就是它的过期时间;
再比如与您每天切身相关的产品需求,过完需求,你给出的上线时间,也就是这个需求的过期时间;
再通俗点讲,您今年的生日过完到明年生日之间也是相当于设置了有效期时间;

以上种种,我们能得出一个结论任何一件事、一个行为动作,都有一个时间、一个节点,甚至我们可以黑localStorage,就是一个完善的API,为什么不能给一个设置过期的机制,因为sessionStorage、Cookie并不能满足我们实际的需求。

思路

问题就简单了,给localStorage一个过期时间,一切就都so easy ?到底是不是,来看看具体的实现吧:

存取示例

//示例一:
localStorage.setItem('test',1234567);
let test = localStorage.getItem('test');
console.log(typeof test, test); 

//示例二:
localStorage['name'] = 'web秀';
console.log(localStorage['name']);
/*
输出:
"1234567" ,'web秀',
这里要注意,1234567 存进去时是number 取出来就成string了
*/

重写 set(存入) 方法:

首先有三个参数 key、value、expired ,分别对应 键、值、过期时间, 过期时间的单位可以自由发挥,小时、分钟、天都可以, 注意点:存储的值可能是数组/对象,不能直接存储,需要转换 JSON.stringify, 这个时间如何设置呢?在这个值存入的时候在键(key)的基础上扩展一个字段,如:key+'expires',而它的值为当前 时间戳 + expired过期时间

具体来看一下代码

set(key, value, expired) {
    /*
    * set 存储方法
    * @ param {String}  key 键
    * @ param {String}  value 值,
    * @ param {String}  expired 过期时间,以分钟为单位,非必须
    */
    let source = this.source;
    source[key] = JSON.stringify(value);
    if (expired){
        source[`${key}__expires__`] = Date.now() + 1000*60*expired
    };
    return value;
}

重写 get(获取) 方法

获取数据时,先判断之前存储的时间有效期,与当前的时间进行对比; 但存储时expired为非必须参数,所以默认为当前时间+1,即长期有效; 如果存储时有设置过期时间,且在获取的时候发现已经小于当前时间戳,则执行删除操作,并返回空值; 注意点:存储的值可能是数组/对象,取出后不能直接返回,需要转换 JSON.parse,

具体来看一下代码 :

get(key) {
    /*
    * get 获取方法
    * @ param {String}  key 键
    * @ param {String}  expired 存储时为非必须字段,所以有可能取不到,默认为 Date.now+1
    */
    const source = this.source,
    expired = source[`${key}__expires__`]||Date.now+1;
    const now = Date.now();

    if ( now >= expired ) {
        this.remove(key);
        return;
    }
    const value = source[key] ? JSON.parse(source[key]) : source[key];
    return value;
}

重写 remove(删除) 方法

remove(key) {
    const data = this.source,
        value = data[key];
    delete data[key];
    delete data[`${key}__expires__`];
    return value;
}
class storage {

    constructor(props) {
        this.props = props || {}
        this.source = this.props.source || window.localStorage
        this.initRun();
    }
    initRun(){
        /*
        * set 存储方法
        * @ param {String}  key 键
        * @ param {String}  value 值,存储的值可能是数组/对象,不能直接存储,需要转换 JSON.stringify
        * @ param {String}  expired 过期时间,以分钟为单位
        */
        const reg = new RegExp("__expires__");
        let data = this.source;
        let list = Object.keys(data);
        if(list.length > 0){
            list.map((key,v)=>{
                if( !reg.test(key )){
                    let now = Date.now();
                    let expires = data[`${key}__expires__`]||Date.now+1;
                    if (now >= expires ) {
                        this.remove(key);
                    };
                };
                return key;
            });
        };
    }
}
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2018年11月16日,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 前言
  • 思路
    • 重写 set(存入) 方法:
      • 重写 get(获取) 方法
        • 重写 remove(删除) 方法
        相关产品与服务
        对象存储
        对象存储(Cloud Object Storage,COS)是由腾讯云推出的无目录层次结构、无数据格式限制,可容纳海量数据且支持 HTTP/HTTPS 协议访问的分布式存储服务。腾讯云 COS 的存储桶空间无容量上限,无需分区管理,适用于 CDN 数据分发、数据万象处理或大数据计算与分析的数据湖等多种场景。
        领券
        问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档