欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

利用js-cookie實現(xiàn)前端設(shè)置緩存數(shù)據(jù)定時失效

 更新時間:2019年06月18日 09:42:11   作者:bayi_lzp  
這篇文章主要介紹了利用js-cookie實現(xiàn)前端設(shè)置緩存數(shù)據(jù)定時失效,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習或者工作具有一定的參考學(xué)習價值,需要的朋友們下面隨著小編來一起學(xué)習學(xué)習吧

一、背景

業(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)文章

  • js實現(xiàn)按鈕進行某行上移下移

    js實現(xiàn)按鈕進行某行上移下移

    這篇文章主要為大家詳細介紹了js實現(xiàn)按鈕進行某行上移下移,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-02-02
  • 原生js封裝二級城市下拉列表的實現(xiàn)代碼

    原生js封裝二級城市下拉列表的實現(xiàn)代碼

    下面小編就為大家?guī)硪黄鷍s封裝二級城市下拉列表的實現(xiàn)代碼。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-06-06
  • javascript實現(xiàn)用戶管理系統(tǒng)

    javascript實現(xiàn)用戶管理系統(tǒng)

    這篇文章主要為大家詳細介紹了javascript實現(xiàn)用戶管理系統(tǒng),文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-06-06
  • JavaScript通過prototype給對象定義屬性用法實例

    JavaScript通過prototype給對象定義屬性用法實例

    這篇文章主要介紹了JavaScript通過prototype給對象定義屬性用法,實例分析了prototype的功能及使用技巧,具有一定參考借鑒價值,需要的朋友可以參考下
    2015-03-03
  • JavaScript?error瀏覽器端錯誤捕獲處理方法筆記解決示例

    JavaScript?error瀏覽器端錯誤捕獲處理方法筆記解決示例

    這篇文章主要為大家介紹了JavaScript?error瀏覽器端錯誤捕獲處理方法筆記解決示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-06-06
  • JS簡單實現(xiàn)點擊復(fù)制鏈接的方法

    JS簡單實現(xiàn)點擊復(fù)制鏈接的方法

    這篇文章主要介紹了JS簡單實現(xiàn)點擊復(fù)制鏈接的方法,提供了2種簡單的復(fù)制鏈接操作方法供大家選擇使用,需要的朋友可以參考下
    2016-08-08
  • JS實現(xiàn)從對象獲取對象中單個鍵值的方法示例

    JS實現(xiàn)從對象獲取對象中單個鍵值的方法示例

    這篇文章主要介紹了JS實現(xiàn)從對象獲取對象中單個鍵值的方法,涉及javascript數(shù)組對象遍歷、事件監(jiān)聽、處理等相關(guān)操作技巧,需要的朋友可以參考下
    2019-06-06
  • 前端云原生之微信小程序云服務(wù)配置指南

    前端云原生之微信小程序云服務(wù)配置指南

    前端邊界又拓寬,走進火熱的云原生云開發(fā)賽道,隨著云原生時代的到來,各大廠紛紛上云,下面這篇文章主要給大家介紹了關(guān)于前端云原生之微信小程序云服務(wù)配置的相關(guān)資料,需要的朋友可以參考下
    2022-05-05
  • Javascript 虛擬 DOM詳解

    Javascript 虛擬 DOM詳解

    這篇文章主要為大家介紹了Javascript 虛擬 DOM,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2021-12-12
  • JavaScript實現(xiàn)模仿桌面窗口的方法

    JavaScript實現(xiàn)模仿桌面窗口的方法

    這篇文章主要介紹了JavaScript實現(xiàn)模仿桌面窗口的方法,可實現(xiàn)模仿桌面窗口的打開、關(guān)閉、移動、縮放及最大化、最小化等功能,需要的朋友可以參考下
    2015-07-07

最新評論