利用js-cookie實現(xiàn)前端設(shè)置緩存數(shù)據(jù)定時失效
一、背景
業(yè)務(wù)需要在前端進行數(shù)據(jù)的緩存,到期就刪除再進行獲取新數(shù)據(jù)。
二、實現(xiàn)過程
前端設(shè)置數(shù)據(jù)定時失效的可以有下面2種方法:
1、當數(shù)據(jù)較大時,可以利用localstorage,存數(shù)據(jù)時候?qū)懭胍粋€時間,獲取的時候再與當前時間進行比較
2、如果數(shù)據(jù)不超過cookie的限制大小,可以利用cookie比較方便,直接設(shè)置有效期即可。
3、更多(請大神指點)
利用localstorage實現(xiàn)
localstorage實現(xiàn)思路:
1、存儲數(shù)據(jù)時加上時間戳
在項目開發(fā)中,我們可以寫一個公用的方法來進行存儲的時候加上時間戳
export function setLocalStorageAndTime (key, value) { window.localStorage.setItem(key, JSON.stringify({ data: value, time: new Date().getTime() })) }
項目中應(yīng)用
存儲
// 有數(shù)據(jù)再進行存儲 setLocalStorageAndTime('XXX', {name: 'XXX'})
讀取
// 判斷是否返回為null或者失效 getLocalStorageAndTime('XXX', 86400000)
2、獲取數(shù)據(jù)時與當前時間進行比較
export function getLocalStorageAndTime (key, exp = 86400000) { // 獲取數(shù)據(jù) 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實現(xiàn)
我們用js-cookie這款插件來設(shè)置cookie,比較方便,可以自行查看文檔。
js-cookie 的示例中只有以天為單位的有效期:
Cookies.set('name', 'value', { expires: 7 }); // 7 天后失效
官方文檔只要設(shè)置天數(shù),沒有時分秒,這樣我們想設(shè)置更小單位的時候無法下手,其實也可以設(shè)置時間戳來處理時間的,下面這種方式可以設(shè)置任意單位的有效期:
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' /* * 設(shè)置cookies * */ export function getCookies (key) { return Cookies.get(key) } /* * 設(shè)置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) }
三、總結(jié)
上面兩個方法各有各的優(yōu)點和缺點,如果小伙伴們有更好方法,麻煩留言互相學(xué)習
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
javascript實現(xiàn)用戶管理系統(tǒng)
這篇文章主要為大家詳細介紹了javascript實現(xiàn)用戶管理系統(tǒng),文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-06-06JavaScript通過prototype給對象定義屬性用法實例
這篇文章主要介紹了JavaScript通過prototype給對象定義屬性用法,實例分析了prototype的功能及使用技巧,具有一定參考借鑒價值,需要的朋友可以參考下2015-03-03JavaScript?error瀏覽器端錯誤捕獲處理方法筆記解決示例
這篇文章主要為大家介紹了JavaScript?error瀏覽器端錯誤捕獲處理方法筆記解決示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-06-06