利用js-cookie实现前端设置缓存数据定时失效


Posted in Javascript onJune 18, 2019

一、背景

业务需要在前端进行数据的缓存,到期就删除再进行获取新数据。

二、实现过程

前端设置数据定时失效的可以有下面2种方法:

1、当数据较大时,可以利用localstorage,存数据时候写入一个时间,获取的时候再与当前时间进行比较
2、如果数据不超过cookie的限制大小,可以利用cookie比较方便,直接设置有效期即可。
3、更多(请大神指点)

利用localstorage实现

localstorage实现思路:

1、存储数据时加上时间戳

在项目开发中,我们可以写一个公用的方法来进行存储的时候加上时间戳

export function setLocalStorageAndTime (key, value) {
 window.localStorage.setItem(key, JSON.stringify({ data: value, time: new Date().getTime() }))
}

项目中应用

存储

// 有数据再进行存储
   setLocalStorageAndTime('XXX', {name: 'XXX'})

读取

// 判断是否返回为null或者失效
getLocalStorageAndTime('XXX', 86400000)

2、获取数据时与当前时间进行比较

export function getLocalStorageAndTime (key, exp = 86400000) {
 // 获取数据
 let data = window.localStorage.getItem(key)
 if (!data) return null
 let dataObj = JSON.parse(data)
 // 与过期时间比较
 if (new Date().getTime() - dataObj.time > exp) {
  // 过期删除返回null
  removeLocalStorage(key)
  console.log('信息已过期')
  return null
 } else {
  return dataObj.data
 }
}

利用cookie实现

我们用js-cookie这款插件来设置cookie,比较方便,可以自行查看文档。

js-cookie 的示例中只有以天为单位的有效期:

Cookies.set('name', 'value', { expires: 7 }); // 7 天后失效

官方文档只要设置天数,没有时分秒,这样我们想设置更小单位的时候无法下手,其实也可以设置时间戳来处理时间的,下面这种方式可以设置任意单位的有效期:

let seconds = 10;
let expires = new Date(new Date() * 1 + seconds * 1000);
Cookies.set('username', 'tanggaowei', { expires: expires }); // 10 秒后失效

贴上利用js-cookie的封装, 记得 npm i js-cookie

import Cookies from 'js-cookie'

/*
* 设置cookies
* */
export function getCookies (key) {
 return Cookies.get(key)
}
/*
* 设置Cookies
* */
export function setCookies (key, value, expiresTime) {
 let seconds = expiresTime
 let expires = new Date(new Date() * 1 + seconds * 1000)
 return Cookies.set(key, value, { expires: expires })
}
/*
* 移除Cookies
* */
export function removeCookies (key) {
 return Cookies.remove(key)
}

三、总结

上面两个方法各有各的优点和缺点,如果小伙伴们有更好方法,麻烦留言互相学习

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
jQuery ui 1.7更新小结
Aug 15 Javascript
jQuery源码分析-02正则表达式 RegExp 常用正则表达式
Nov 14 Javascript
javascript打开word文档的方法
Apr 16 Javascript
AngularJS的内置过滤器详解
May 14 Javascript
Javascript实现字数统计
Jul 03 Javascript
jQuery实现可用于博客的动态滑动菜单完整实例
Sep 17 Javascript
Eclipse编辑jsp、js文件时卡死现象的解决办法汇总
Feb 02 Javascript
javascript实现简单的可随机变色网页计算器示例
Dec 30 Javascript
ES6新特性之类(Class)和继承(Extends)相关概念与用法分析
May 24 Javascript
node Buffer缓存区常见操作示例
May 04 Javascript
jQuery zTree树插件的使用教程
Aug 16 jQuery
JQuery使用数组遍历跳出each循环
Sep 01 jQuery
vue中利用Promise封装jsonp并调取数据
Jun 18 #Javascript
实用Javascript调试技巧分享(小结)
Jun 18 #Javascript
Angular中innerHTML标签的样式不起作用的原因解析
Jun 18 #Javascript
小程序click-scroll组件设计
Jun 18 #Javascript
在JavaScript中如何访问暂未存在的嵌套对象
Jun 18 #Javascript
用Vue.js在浏览器中实现裁剪图像功能
Jun 18 #Javascript
JS删除String里某个字符的方法
Jan 06 #Javascript
You might like
PHP经典面试题集锦
2015/03/19 PHP
php无限级分类实现评论及回复功能
2019/02/18 PHP
thinkphp5.1 框架导入/导出excel文件操作示例
2020/05/25 PHP
优秀js开源框架-jQuery使用手册(1)
2007/03/10 Javascript
jQuery技巧大放送 学习jquery的朋友可以看下
2009/10/14 Javascript
javascript中打印当前的时间实现思路及代码
2013/12/18 Javascript
JS二维数组的定义说明
2014/03/03 Javascript
jquery实现简单手风琴菜单效果实例
2015/06/13 Javascript
通过js获取上传的图片信息(临时保存路径,名称,大小)然后通过ajax传递给后端的方法
2015/10/01 Javascript
JavaScript代码实现禁止右键、禁选择、禁粘贴、禁shift、禁ctrl、禁alt
2015/11/17 Javascript
JavaScript与HTML的结合方法详解
2015/11/23 Javascript
微信小程序(应用号)开发新闻客户端实例
2016/10/24 Javascript
从零学习node.js之利用express搭建简易论坛(七)
2017/02/25 Javascript
jQuery+ajax实现局部刷新的两种方法
2017/06/08 jQuery
vue2.0 循环遍历加载不同图片的方法
2018/03/06 Javascript
JS实现的合并多个数组去重算法示例
2018/04/11 Javascript
一篇文章介绍redux、react-redux、redux-saga总结
2019/05/23 Javascript
微信小程序基于高德地图查找位置并显示文字
2019/10/30 Javascript
javascript实现视频弹幕效果(两个版本)
2019/11/28 Javascript
iSlider手机端图片滑动切换插件使用详解
2019/12/24 Javascript
[47:36]Optic vs Newbee 2018国际邀请赛小组赛BO2 第二场 8.17
2018/08/18 DOTA
Python操作MySQL简单实现方法
2015/01/26 Python
Python实现简易Web爬虫详解
2018/01/03 Python
Python基于最小二乘法实现曲线拟合示例
2018/06/14 Python
python 实现敏感词过滤的方法
2019/01/21 Python
python实现五子棋小程序
2019/06/18 Python
python3 mmh3安装及使用方法
2019/10/09 Python
python GUI库图形界面开发之PyQt5树形结构控件QTreeWidget详细使用方法与实例
2020/03/02 Python
python与idea的集成的实现
2020/11/20 Python
matplotlib自定义鼠标光标坐标格式的实现
2021/01/08 Python
日本化妆品植村秀俄罗斯官方网站:Shu Uemura俄罗斯
2020/02/01 全球购物
const char*, char const*, char*const的区别是什么
2014/07/09 面试题
表扬稿格式范文
2015/01/16 职场文书
公务员的复习计划书,请收下!
2019/07/15 职场文书
导游词之镜泊湖
2019/12/09 职场文书
CSS 伪元素::marker详解
2021/06/26 HTML / CSS