国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

利用js-cookie實現前端設置緩存數據定時失效

2019-11-19 11:19:13
字體:
來源:轉載
供稿:網友

一、背景

業務需要在前端進行數據的緩存,到期就刪除再進行獲取新數據。

二、實現過程

前端設置數據定時失效的可以有下面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)}

三、總結

上面兩個方法各有各的優點和缺點,如果小伙伴們有更好方法,麻煩留言互相學習

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 隆昌县| 安陆市| 巢湖市| 余庆县| 彝良县| 乡城县| 涿州市| 蓬莱市| 鞍山市| 无极县| 榕江县| 尤溪县| 嘉定区| 武冈市| 建德市| 中西区| 宕昌县| 上虞市| 当涂县| 文登市| 建水县| 嘉峪关市| 科技| 柘荣县| 东莞市| 谷城县| 寿光市| 桓台县| 永和县| 淳化县| 桓仁| 山丹县| 洞口县| 吴忠市| 义马市| 潞西市| 昂仁县| 重庆市| 博客| 汉寿县| 虞城县|