91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

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

發布時間:2020-10-22 11:23:23 來源:腳本之家 閱讀:225 作者:bayi_lzp 欄目:web開發

一、背景

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

二、實現過程

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

三、總結

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

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

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

深泽县| 平山县| 虹口区| 修文县| 海宁市| 辽阳县| 平安县| 西宁市| 栖霞市| 唐海县| 慈利县| 安达市| 琼海市| 会宁县| 紫阳县| 华安县| 雷波县| 普洱| 五大连池市| 建阳市| 广南县| 达尔| 东乌| 本溪市| 江阴市| 孙吴县| 木兰县| 二连浩特市| 黎川县| 内黄县| 静安区| 乡宁县| 荃湾区| 双桥区| 武宁县| 西乌珠穆沁旗| 章丘市| 秀山| 浦城县| 万荣县| 石渠县|