自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

90%的人封裝Storage時忽略了一個點!你們知道封裝的意義是啥嗎?

開發(fā)
本文就是想讓大家知道,封裝 Storage 的時候,類型猜測是一個最基本的功能,有這個功能,使用者更方便、更無腦地使用?。

二次封裝 Storage?

關(guān)于 Storage 的封裝問題,其實都是老生常談了,很多人都會在項目中去二次封裝 Storage,為了讓開發(fā)者能更加方便地去使用 localStore、sessionStorage。就比如下方,應(yīng)該是很多人封裝的案例,就是封裝簡單的 讀取、寫入,或者有 刪除、清空:

我們?yōu)槭裁捶庋b?

要不我們回過頭來想一下,我們?yōu)槭裁匆庋b?其實封裝無非就是為了兩個目的:

  • 更好地統(tǒng)一維護
  • 使用者更方便、更無腦地使用

但是我覺得在一個大項目中以及緊急的開發(fā)進度中,使用者更方便、更無腦地使用才是封裝的第一目的,所以想想剛剛的 LocalStorage 的封裝,真的能讓使用者更方便、更無腦地使用嗎?

我就舉個例子吧,我想存進去一個對象,我這么去存,可以嗎?

顯然是不行的,存進去的對象會被轉(zhuǎn)成字符串 [object Object]:

所以我必須這么去存和取值,利用 JSON.parse、JSON.stringify 去轉(zhuǎn):

只有這么去做才能達到我的目的:

但是這樣不覺得很麻煩嗎?使用者更方便、更無腦地使用是封裝的第一目的,顯然這樣只會讓使用者徒增煩惱?。?!

有的人就說了,可以把 JSON.parse、JSON.stringify 寫在 useLocalStorage 中,但是這個方案只是針對 Object 而已,但是數(shù)據(jù)類型其實有多種:number、string、object、set、map、date 等等,你直接寫在里面,不太合理,你得兼顧所有的數(shù)據(jù)類型才行??!

類型猜測邏輯

所以呢,你如果想要讓使用者更方便、更無腦地使用,我們可以封裝一套類型猜測邏輯。

首先我們必須準備一個函數(shù),這個函數(shù)用來判斷數(shù)據(jù)類型:

但是光是判斷出類型還不夠啊,我們還必須給每一種類型,準備一套 讀取、存入 的策略:

最后只需要:

  • 判斷類型
  • 獲取類型對應(yīng)的存取策略
  • 在存取的時候執(zhí)行對應(yīng)策略

我們現(xiàn)在可以來試試能不能達到目的:

顯然已經(jīng)達到我們想要的效果:

小結(jié)

當然, Storage 的封裝不僅僅是類型猜測這么一個功能點!而且其實封裝還有很多兜底的情況我這里沒寫出來,本文就是想讓大家知道,封裝 Storage 的時候,類型猜測是一個最基本的功能,有這個功能,使用者更方便、更無腦地使用。

責(zé)任編輯:趙寧寧 來源: 前端之神
相關(guān)推薦

2015-10-23 09:34:16

2024-08-01 17:34:56

Promiseaxios請求

2022-09-16 11:41:17

Spring代碼

2020-08-07 16:18:38

JavaScriptC++Python

2021-03-15 08:02:43

線性結(jié)構(gòu)PriorityQue

2018-06-05 09:13:47

2021-08-26 21:55:38

DPU架構(gòu)數(shù)據(jù)

2018-07-11 15:54:23

趨勢互聯(lián)網(wǎng)投資

2015-04-23 16:21:23

2023-08-31 12:01:14

數(shù)據(jù)分析體系

2015-09-21 14:22:43

2025-05-07 00:25:00

芯片焊料PC

2020-03-12 08:28:09

文件Java開發(fā)

2020-08-24 13:15:59

Python代碼描述符

2020-08-24 15:25:27

Python 開發(fā)運維

2022-06-27 08:00:49

hook工具庫函數(shù)

2022-07-20 09:06:27

Hook封裝工具庫

2025-04-16 07:06:43

2021-07-27 14:50:15

axiosHTTP前端

2023-10-08 09:42:41

GitHubDataTable?Fill
點贊
收藏

51CTO技術(shù)棧公眾號