JS項目中對本地存儲進行二次的封裝的實現(xiàn)
前言
平時在開發(fā)的中,發(fā)現(xiàn)身邊同事在使用localStorage和sessionStorage的時候,喜歡在代碼里面直接調(diào)用,舉個的栗子:
function login() {
//...請求
const userInfo = {userId: 123, userName: '張三'}
sessionStorage.setItem('userInfo', JSON.stringify(userInfo))
}
function getUserInfo() {
return JSON.parse(sessionStorage.getItem('userInfo'))
}并不是覺得直接調(diào)用不好,但總覺得這種寫法不夠語義化,于是將其進行封裝,這里參考了后端java同事的實體類的邏輯。
定義恒量的鍵名
這里我們將要使用到的key存儲下來,新建一個叫constant-storage.js的文件,對外暴露一些key的鍵名,也方便后期統(tǒng)一修改,這里因為都是恒量,所以名稱我們都用大寫表示。
export const USER_INFO = 'userInfo'
下層實現(xiàn)
這里我們開始定義處理localStorage和sessionStorage的類,首先給這個類定義基本的存儲方法,set 、get、clear,對最基本的邏輯進行一個封裝,這里用sessionStorage做個例子:
class Session {
constructor() {
this.store = window.sessionStorage
}
set(key, value) {
this.store.setItem(key, value)
}
get(key) {
return this.store.getItem(key)
}
clear(key) {
this.store.removeItem(key)
}
clearAll() {
this.store.clear()
}
}
然后我們在開始封裝一些業(yè)務(wù)功能,例如存取用戶信息userInfo,從恒量中取出key,再將這個類,實例化暴露出去供外部調(diào)用。
import { USER_INFO } from './constant-storage'
class Session {
constructor() {
this.store = window.sessionStorage
}
set(key, value) {
this.store.setItem(key, value)
}
get(key) {
return this.store.getItem(key)
}
clear(key) {
this.store.removeItem(key)
}
clearAll() {
this.store.clear()
}
// 用戶信息
getUserInfo() {
const userInfo = this.get(USER_INFO)
return userInfo ? JSON.parse(userInfo) : null
}
setUserInfo(userInfo) {
this.set(USER_INFO, JSON.stringify(userInfo))
}
clearUserInfo() {
this.clear(USER_INFO)
}
}
const session = new Session()
export default session
上層調(diào)用
引入我們暴露的實例,再回頭看看我們直接對用戶信息的存儲操作。
import session from './session'
function login() {
//...請求
const userInfo = {userId: 123, userName: '張三'}
session.setUserInfo(userInfo)
}
function getUserInfo() {
return session.getUserInfo()
}總結(jié)
這里我覺得我們將下層實現(xiàn)與上層使用的邏輯拆分開了,符合單一職責原則,邏輯更清晰。
- 上層無需關(guān)心底層的實現(xiàn)邏輯,只需要在合適的時機調(diào)用,自己只要專注于業(yè)務(wù)邏輯就好。(我不希望去糾結(jié)于sessionStorage與JSON的序列化邏輯,我只希望我可以方便的存儲的數(shù)據(jù),也可以方便的獲取數(shù)據(jù))
- 下層也無需關(guān)心上層的業(yè)務(wù)邏輯,只提供實現(xiàn)的方法,供外部調(diào)用即可。(我不希望糾結(jié)于你的業(yè)務(wù),我能滿足你的要求,你不要管我怎么存儲數(shù)據(jù),怎么對數(shù)據(jù)進行處理,至于我怎么實現(xiàn),那是我自己的事情)
到此這篇關(guān)于JS項目中對本地存儲進行二次的封裝的文章就介紹到這了,更多相關(guān)js本地存儲二次封裝內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
在IE,Firefox,Safari,Chrome,Opera瀏覽器上調(diào)試javascript
前支持javascript調(diào)試功能的工具越來越多,主要分為ie和firefox兩大陣營。其他瀏覽器上很難調(diào)試javascript。而Javascript Debug Toolkit解決了這個問題,可能在所有支持ajax請求的瀏覽器上調(diào)試javascript.2008-12-12
給事件響應(yīng)函數(shù)傳參數(shù)的四種方式小結(jié)
這篇文章主要介紹了給事件響應(yīng)函數(shù)傳參數(shù)的四種方式。需要的朋友可以過來參考下,希望對大家有所幫助2013-12-12
webpack中的filename 和 chunkFilename 的區(qū)別實例解析
filename 指列在 entry 中,打包后輸出的文件的名稱,chunkFilename 指未列在 entry 中,卻又需要被打包出來的文件的名稱,這篇文章主要介紹了webpack中的filename 和 chunkFilename 的區(qū)別實例解析,需要的朋友可以參考下2023-11-11
JavaScript實現(xiàn)獲取網(wǎng)絡(luò)通信進度
這篇文章主要為大家詳細介紹了如何使用Fetch?API和XMLHttpRequest(XHR)來執(zhí)行網(wǎng)絡(luò)請求,并重點說明如何獲取這兩種方法的網(wǎng)絡(luò)請求進度,感興趣的可以了解下2023-12-12
關(guān)于JS中match() 和 exec() 返回值和屬性的測試
這篇文章主要介紹了關(guān)于JS中match() 和 exec() 返回值和屬性的測試 的相關(guān)資料,需要的朋友可以參考下2016-03-03

