精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

面試官: 如何讓localStorage支持過期時間設置?

開發 前端
localStorage 屬性允許我們訪問一個 Document 源(origin)的對象 Storage;存儲的數據將保存在瀏覽器會話中。

[[440024]]

聊到 localStorage 想必熟悉前端的朋友都不會陌生, 我們可以使用它提供的 getItem, setItem, removeItem, clear 這幾個 API 輕松的對存儲在瀏覽器本地的數據進行讀,寫, 刪操作, 但是相比于 cookie, localStorage 唯一美中不足的就是不能設置每一個鍵的過期時間。

localStorage 屬性允許我們訪問一個 Document 源(origin)的對象 Storage;存儲的數據將保存在瀏覽器會話中。localStorage 類似 sessionStorage,但其區別在于:存儲在 localStorage 的數據可以長期保留;而當頁面會話結束——也就是說,當頁面被關閉時,存儲在 sessionStorage 的數據會被清除 。

我們還應注意,localStorage 中的鍵值對總是以字符串的形式存儲。

問題描述

在實際的應用場景中, 我們往往需要讓 localStorage 設置的某個 key 能在指定時間內自動失效, 所以基于這種場景, 我們如何去解決呢?

1. 初級解法

對于剛熟悉前端的朋友, 可能會立馬給出答案:

  1. localStorage.setItem('dooring''1.0.0'
  2. // 設置一小時的有效期 
  3. const expire = 1000 * 60 * 60; 
  4. setTimeout(() => { 
  5.   localStorage.setItem('dooring'''
  6. }, expire) 

當然這種方案能解決一時的問題, 但是如果要設置任意鍵的有效期, 使用這種方案就需要編寫多個定時器, 維護成本極高, 且不利于工程化復用。

2. 中級解法

前端工程師在有一定的工作經驗之后, 往往會去考慮工程化和復用性的問題, 并對數據結構有了一定的了解, 所以可能會有接下來的解法:

  1. 用localStorage存一份{key(鍵): expire(過期時間)}的映射表
  2. 重寫localStorage API, 對方法進行二次封裝

類似的代碼如下:

  1. const store = { 
  2.   // 存儲過期時間映射 
  3.   setExpireMap: (key, expire) => { 
  4.     const expireMap = localStorage.getItem('EXPIRE_MAP') || "{}" 
  5.     localStorage.setItem( 
  6.       'EXPIRE_MAP',  
  7.       JSON.stringify({ 
  8.       ...JSON.parse(expireMap), 
  9.       key: expire 
  10.     })) 
  11.   }, 
  12.   setItem: (key, value, expire) => { 
  13.     store.setExpireMap(key, expire) 
  14.     localStorage.setItem(key, value) 
  15.   }, 
  16.   getItem: (key) => { 
  17.     // 在取值之前先判斷是否過期 
  18.     const expireMap = JSON.parse( 
  19.       localStorage.getItem('EXPIRE_MAP') || "{}" 
  20.     ) 
  21.     if(expireMap[key] && expireMap[key] < Date.now()) { 
  22.       return localStorage.getItem(key
  23.     }else { 
  24.       localStorage.removeItem(key
  25.       return null 
  26.     } 
  27.   } 
  28.   // ... 

眨眼一看這個方案確實解決了復用性的問題, 并且不同團隊都可以使用這個方案, 但仍然有一些缺點:

  • 對 store 操作時需要維護2份數據, 并且占用緩存空間
  • 如果 EXPIRE_MAP 誤刪除將會導致所有過期時間失效
  • 對操作過程缺少更靈活的控制(比如操作狀態, 操作回調等)

3. 高級解法

為了減少維護成本和空間占用, 并支持一定的靈活控制和容錯能力, 我們又應該怎么做呢?

這里筆者想到了兩種類似的方案:

  1. 將過期時間存到 key 中, 如 dooring|6000, 每次取值時通過分隔符“|”來將 key 和 expire 取出, 進行判斷
  2. 將過期時間存到 value 中, 如 1.0.0|6000, 剩下的同1

為了更具有封裝性和可靠性, 我們還可以配置不同狀態下的回調, 簡單實現如下:

  1. const store = { 
  2.   preId: 'xi-'
  3.   timeSign: '|-door-|'
  4.   status: { 
  5.     SUCCESS: 0, 
  6.     FAILURE: 1, 
  7.     OVERFLOW: 2, 
  8.     TIMEOUT: 3, 
  9.   }, 
  10.   storage: localStorage || window.localStorage, 
  11.   getKey: function (key: string) { 
  12.     return this.preId + key
  13.   }, 
  14.   setfunction ( 
  15.     key: string, 
  16.     value: string | number, 
  17.     time?: Date & number, 
  18.     cb?: (status: number, key: string, value: string | number) => void, 
  19.   ) { 
  20.     let _status = this.status.SUCCESS, 
  21.       _key = this.getKey(key), 
  22.       _time; 
  23.     // 設置失效時間,未設置時間默認為一個月 
  24.     try { 
  25.       _time = time 
  26.         ? new Date(time).getTime() || time.getTime() 
  27.         : new Date().getTime() + 1000 * 60 * 60 * 24 * 31; 
  28.     } catch (e) { 
  29.       _time = new Date().getTime() + 1000 * 60 * 60 * 24 * 31; 
  30.     } 
  31.     try { 
  32.       this.storage.setItem(_key, _time + this.timeSign + value); 
  33.     } catch (e) { 
  34.       _status = this.status.OVERFLOW; 
  35.     } 
  36.     cb && cb.call(this, _status, _key, value); 
  37.   }, 
  38.   get: function ( 
  39.     key: string, 
  40.     cb?: (status: number, value: string | number | null) => void, 
  41.   ) { 
  42.     let status = this.status.SUCCESS, 
  43.       _key = this.getKey(key), 
  44.       value = null
  45.       timeSignLen = this.timeSign.length, 
  46.       that = this, 
  47.       index
  48.       time
  49.       result; 
  50.     try { 
  51.       value = that.storage.getItem(_key); 
  52.     } catch (e) { 
  53.       result = { 
  54.         status: that.status.FAILURE, 
  55.         value: null
  56.       }; 
  57.       cb && cb.call(this, result.status, result.value); 
  58.       return result; 
  59.     } 
  60.     if (value) { 
  61.       index = value.indexOf(that.timeSign); 
  62.       time = +value.slice(0, index); 
  63.       if (time > new Date().getTime() || time == 0) { 
  64.         value = value.slice(index + timeSignLen); 
  65.       } else { 
  66.         (value = null), (status = that.status.TIMEOUT); 
  67.         that.remove(_key); 
  68.       } 
  69.     } else { 
  70.       status = that.status.FAILURE; 
  71.     } 
  72.     result = { 
  73.       status: status, 
  74.       value: value, 
  75.     }; 
  76.     cb && cb.call(this, result.status, result.value); 
  77.     return result; 
  78.   }, 
  79.   // ... 
  80. }; 
  81.  
  82. export default store; 

這樣, 我們就實現了每個 key 都有獨立的過期時間, 并且對不同的操作結果可以輕松的進行狀態管控啦~

4. 骨灰級解法

當然, 骨灰級解法是直接使用 xijs 這個 javascript 工具庫, 因為我已經將上述完整實現方案封裝到該庫中了, 我們只需要使用如下的方案, 就能輕松使用具有過期時間的強大的 localStorage 方法啦 :

  1. //  先安裝 yarn add xijs 
  2. import { store } from 'xijs'
  3. // 設置帶有過期時間的key 
  4. store.set('name''dooring'Date.now() + 1000); 
  5. console.log(store.get('name')); 
  6. setTimeout(() => { 
  7.   console.log(store.get('name')); 
  8. }, 1000); 
  9.  
  10. // 設置成功后的回調 
  11. store.set('dooring''xuxiaoxi'Date.now() + 1000, (status, key, value) => { 
  12.   console.log('success'); 
  13. }); 

同時 xijs 還在持續擴充更有用的工具函數, 讓業務開發更高效. 目前已集成了如下工具函數:

  • store 基于 localStorage 上層封裝的支持過期時間設置的緩存庫, 支持操作回調
  • uuid 生成唯一id, 支持設置長度
  • randomStr 生成指定個數的隨機字符串
  • formatDate 開箱即用的時間格式化工具
  • debounce 防抖函數
  • throttle 節流函數
  • url2obj 將url字符串轉換為對象
  • obj2url 將對象轉換成編碼后的url字符串
  • isPC 判斷設備是否為PC類型

本文轉載自微信公眾號「趣談前端」

【編輯推薦】

 

責任編輯:姜華 來源: 趣談前端
相關推薦

2024-05-09 10:33:14

JS計算容量

2015-08-13 10:29:12

面試面試官

2024-04-09 08:39:16

本地緩存開發線程安全

2023-02-16 08:10:40

死鎖線程

2024-04-08 10:35:59

JS代碼容量

2024-12-26 10:19:16

2024-02-20 14:10:55

系統緩存冗余

2024-03-18 14:06:00

停機Spring服務器

2024-09-11 22:51:19

線程通訊Object

2025-03-17 00:00:00

2024-04-03 00:00:00

Redis集群代碼

2010-08-12 16:28:35

面試官

2021-07-06 07:08:18

管控數據數倉

2023-11-20 10:09:59

2021-03-01 18:42:02

緩存LRU算法

2019-07-23 09:30:17

HTTP 2.0HTTP協議傳輸

2024-04-23 14:09:59

JavaScript開發

2019-04-29 14:59:41

Tomcat系統架構

2021-02-06 09:21:17

MySQL索引面試

2022-05-23 08:43:02

BigIntJavaScript內置對象
點贊
收藏

51CTO技術棧公眾號

亚洲作爱视频| 全球最大av网站久久| 成人午夜免费电影| 欧美一区二区三区四区在线| 51妺嘿嘿午夜福利| 久久亚洲人体| 亚洲国产你懂的| 日本成人三级电影网站| 99riav国产| 99热精品在线观看| 日日狠狠久久偷偷四色综合免费| 久久精品无码一区二区三区毛片| 爱搞国产精品| 国产精品久久久久久户外露出| 97人人模人人爽人人少妇| www亚洲视频| 亚洲欧美偷拍自拍| 国产亚洲视频在线观看| 国产免费a级片| 成人黄色在线| 精品久久香蕉国产线看观看亚洲| 一区二区三区观看| 欧洲毛片在线| 成人在线综合网| 成人欧美一区二区三区黑人孕妇| 在线观看 中文字幕| 911久久香蕉国产线看观看| 日韩国产欧美精品一区二区三区| 日本网站在线看| 精品亚洲美女网站| 激情成人中文字幕| 日本丰满少妇黄大片在线观看| 青青视频在线观| 国产美女精品在线| 国产精品露脸av在线| 男人的天堂一区| 国内在线观看一区二区三区| 久久久www成人免费精品张筱雨 | 日本精品视频| 欧美日韩国产成人在线免费| 欧美一级片中文字幕| av手机免费在线观看| 亚洲免费电影在线| 中文字幕在线亚洲精品| av一本在线| 国产三级一区二区三区| 久久综合九色综合网站| 欧美在线 | 亚洲| 国产超碰在线一区| av一本久道久久波多野结衣| 国产精品久久久久毛片| 久久av资源网| 成人国产在线激情| 国产人妻精品一区二区三| 激情综合色综合久久| 国产精品久久色| 中文字幕久久久久| 美女视频黄频大全不卡视频在线播放| 国产成人精品免高潮在线观看| 精品人妻无码一区二区性色| 国产日韩亚洲欧美精品| 国产91精品久久久| 久久精品久久久久久久| 日本成人在线电影网| 国产精品老女人精品视频 | 日韩免费在线观看| 国产精品91av| 久久午夜影院| 亚洲欧美激情视频| 快灬快灬一下爽蜜桃在线观看| 成人亚洲一区| 精品国产一区二区三区久久| 九九热最新地址| 亚洲午夜91| 午夜精品久久久久久久99热浪潮| 亚洲欧美在线视频免费| 乱码第一页成人| 国产精品久久一区主播| 99在线小视频| 99国内精品久久| 久久精品日韩| 在线免费观看黄色av| 亚洲欧美日韩中文字幕一区二区三区| 欧美中日韩在线| 三妻四妾的电影电视剧在线观看| 精品久久久久久亚洲精品| 久久久久免费精品| 精品视频一区二区三区在线观看| 亚洲国产成人久久综合| 中文字幕第20页| 亚洲中无吗在线| 1769国产精品| 国产一区二区三区黄片| 高清视频一区二区| 日韩欧美亚洲日产国| 黄色网页在线观看| 欧美日韩国产精品一区二区三区四区 | 91久久国产精品91久久性色| 国产91免费看| 中文字幕亚洲综合久久菠萝蜜| 久久这里只有精品8| 激情开心成人网| 欧美一卡在线观看| av男人的天堂av| 影音先锋一区| 国产日韩视频在线观看| 亚洲人成色777777老人头| 国产精品乱码妇女bbbb| 波多野结衣综合网| 国产精品高清一区二区| 精品偷拍一区二区三区在线看| 看黄色录像一级片| 校园激情久久| 肥熟一91porny丨九色丨| 国产精品二线| 天天色天天操综合| 国产在线视频三区| 操欧美老女人| 日本精品久久中文字幕佐佐木| 99久久精品国产色欲| 国产性做久久久久久| 妞干网在线观看视频| 亚洲天堂网站| 国产午夜精品全部视频在线播放| 国产一级片播放| 国产又粗又猛又爽又黄91精品| 欧美成人免费在线| www视频在线观看| 欧美一卡二卡三卡四卡| 国产wwwwxxxx| 日韩精品国产欧美| 欧美日韩高清在线一区| av在线播放资源| 精品噜噜噜噜久久久久久久久试看 | 91视频免费版污| 亚洲精品无吗| 91精品国产网站| 五月天丁香视频| 午夜亚洲国产au精品一区二区 | 久久综合国产精品| 鲁一鲁一鲁一鲁一色| 大陆精大陆国产国语精品| 欧美黑人国产人伦爽爽爽| 国产精品视频在线观看免费| 国产精品第五页| 亚洲一区二区三区四区五区| 日韩精品影视| 国产日本欧美一区| 免费网站看v片在线a| 欧美绝品在线观看成人午夜影视| 又色又爽的视频| 美女脱光内衣内裤视频久久影院| 午夜精品电影在线观看| 欧美aaaaaa| 久久久999国产| 精品国产亚洲一区二区麻豆| 亚洲图片自拍偷拍| 小毛片在线观看| 亚洲一区区二区| 欧美婷婷久久| 国产综合色在线观看| 最近2019年好看中文字幕视频| 亚洲天堂男人网| 亚洲蜜臀av乱码久久精品| 制服下的诱惑暮生| 亚洲第一毛片| 欧美日韩在线播放一区二区| 国产经典一区| 久久这里有精品视频| 精品国产亚洲av麻豆| 五月激情综合婷婷| 亚洲一区二区三区日韩 | 黄色国产在线视频| 亚洲女人av| 亚洲成人18| 日韩欧美久久| 热99精品里视频精品| 91福利在线视频| 日韩欧美国产一区二区在线播放| 日本污视频在线观看| 欧美激情综合五月色丁香| 亚洲男人天堂av在线| 国模 一区 二区 三区| 免费久久久一本精品久久区| 久久久久毛片| 久久久久久国产免费| 国产在线91| 日韩视频在线一区二区| 一级片中文字幕| 欧美国产禁国产网站cc| 麻豆tv在线观看| 日韩极品在线观看| 亚洲爆乳无码精品aaa片蜜桃| 日本三级久久| 91午夜理伦私人影院| 欧美13videosex性极品| 日韩视频在线观看免费| 亚洲欧美一区二区三| 欧美久久久一区| 视频一区二区三区四区五区| 亚洲欧洲精品一区二区三区| 给我看免费高清在线观看| 国内精品久久久久影院薰衣草 | 日韩精品视频在线观看网址| 一级黄色小视频| 黑人精品xxx一区| 538精品在线观看| 亚洲国产精品av| 精品人妻一区二区三区香蕉| 国产精品亚洲视频| 日韩av手机版| 99精品视频免费观看| 水蜜桃在线免费观看| 国产欧美一区| 久99久视频| avtt综合网| 91亚洲国产成人久久精品网站| 欧美日韩激情电影| 日本欧美中文字幕| 国产理论在线| 九九精品视频在线观看| 麻豆视频在线观看免费| 伊人久久五月天| 欧美大片aaa| 亚洲精品美女久久久| 亚洲AV无码精品国产| 欧美丰满高潮xxxx喷水动漫| 久草热在线观看| 色爱区综合激月婷婷| xxxxxx国产| 亚洲午夜激情av| 久久免费视频6| 亚洲另类春色国产| 三级黄色录像视频| 国产精品色在线| 日本精品久久久久中文| 久久久久久久国产精品影院| 国产精品无码永久免费不卡| gogo大胆日本视频一区| 美女扒开腿免费视频| 国产91精品欧美| 18禁一区二区三区| 成人永久免费视频| 国产原创剧情av| www.亚洲人| 黄色国产在线观看| 91色|porny| 性欧美精品中出| 国产欧美精品一区二区色综合| 成都免费高清电影| 国产欧美中文在线| 一二三四国产精品| 国产精品久久久久国产精品日日| 国产三级黄色片| 综合欧美亚洲日本| 欧美成人精品欧美一| 亚洲一区二区精品3399| 久久精品久久精品久久| 性久久久久久久久| 黑人一级大毛片| 日本道在线观看一区二区| 69xxxx国产| 欧美情侣在线播放| 国产wwwxxx| 亚洲成在人线av| 欧洲亚洲精品视频| 日韩在线免费av| 色综合999| 91国产美女在线观看| 亚洲wwww| 成人亚洲激情网| 国产另类在线| 日本婷婷久久久久久久久一区二区| 国产a久久精品一区二区三区| 视频一区二区三| 欧美黄色大片网站| 99精品人妻少妇一区二区 | 伊人久久大香线蕉综合四虎小说| 粉嫩av一区二区三区天美传媒| 亚洲国内自拍| 亚洲综合在线网站| 国产精品91xxx| 魔女鞋交玉足榨精调教| 国产精品美女一区二区三区| 欧美三级在线免费观看| 欧美性猛交丰臀xxxxx网站| 亚洲天堂国产精品| 亚洲国产精品99久久| www.在线播放| 久久久久久国产三级电影| 91九色综合| 丁香五月网久久综合| 精品久久久亚洲| 分分操这里只有精品| 日本伊人色综合网| 国产 xxxx| 中文字幕制服丝袜一区二区三区 | 尤物网精品视频| 牛夜精品久久久久久久| 成人深夜福利app| 国产激情av在线| 亚洲成av人片在www色猫咪| 伊人久久亚洲综合| 日韩av在线播放资源| 含羞草www国产在线视频| 茄子视频成人在线| 亚洲码欧美码一区二区三区| 日韩欧美一区二区三区四区五区| 亚洲天堂久久| 在线观看中文av| 中文字幕国产一区二区| 欧美一二三区视频| 日韩午夜在线观看| 91精品专区| 国产成人亚洲综合91精品| 久久精品论坛| 欧美乱做爰xxxⅹ久久久| 久久精品国产一区二区| 右手影院亚洲欧美| 香蕉av福利精品导航| www.成人免费视频| 久久精品一区中文字幕| 8av国产精品爽爽ⅴa在线观看| 国模精品娜娜一二三区| 欧美日韩国产在线一区| 日韩av片免费观看| 国产精品蜜臀av| 高潮毛片又色又爽免费| 亚洲精品一区二区网址| mm视频在线视频| 国产精品香蕉视屏| 亚洲特色特黄| 欧洲成人午夜精品无码区久久| 亚洲欧美另类久久久精品2019| 中文字幕观看视频| 在线成人激情黄色| 欧美性片在线观看| 日韩精品无码一区二区三区| 久久精品免费| 中文字幕人妻一区二区| 色婷婷精品大视频在线蜜桃视频| 五月激情丁香婷婷| 欧洲一区二区视频| 婷婷成人在线| 无码人妻丰满熟妇区毛片| 久久久蜜桃精品| 成人免费毛片视频| 亚洲欧美www| 日韩免费va| 五月天久久狠狠| 久久国产精品一区二区| 免费成人深夜蜜桃视频| 欧美日韩一区二区三区视频 | 久久久久成人网| 国产精品一区二区三区美女| 人妻少妇精品无码专区二区| av电影一区二区| 美日韩一二三区| 亚洲色图激情小说| 国外成人福利视频| 宅男av一区二区三区| 精品亚洲国内自在自线福利| 91九色丨porny丨极品女神| 日韩视频一区二区在线观看| 国产精品69xx| 久久综合九色99| 老司机精品视频在线| 日韩欧美国产成人精品免费| 日韩欧美国产电影| 日韩在线伦理| 在线免费一区| 成人三级伦理片| 精品无码一区二区三区的天堂| 色综合伊人色综合网站| avtt综合网| 日韩福利视频在线| 一区二区三区在线观看网站| 欧洲av在线播放| 国产精品美乳一区二区免费| 亚洲区综合中文字幕日日| 无码国产69精品久久久久网站| 福利精品视频在线| 黄色网在线播放| 久久综合九色综合久99| 国产在线一区观看| 成人毛片18女人毛片| 色偷偷91综合久久噜噜| 粉嫩精品导航导航| 亚洲欧美久久久久| 亚洲大片在线观看| 日韩在线资源| 九九九九精品九九九九| 麻豆精品国产传媒mv男同| 日本一级黄色录像| 日韩在线观看免费av| 欧美18xxxx| 精品国产鲁一鲁一区二区三区| 黑人巨大精品欧美一区二区三区 | 神马精品久久| 91中文字幕一区|