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

我面試最喜歡問的開放題:如何嚴謹二次封裝 localStorage?

開發(fā) 前端
最近我在面試中,喜歡問一道有關(guān)于 hooks 的開放問題:二次封裝一個 loaclStorage 的 hooks 時,需要考慮哪些問題呢?

在很多公司中,內(nèi)部都會封裝一些適用于公司內(nèi)部業(yè)務的方法庫來提高整個團隊的開發(fā)效率,比如:

  • 防抖節(jié)流
  • 懶加載、虛擬滾動
  • dom增刪改查、移動、拖拽
  • 管理狀態(tài)

而在 Vue3 項目中,這種方法庫表現(xiàn)為:hooks庫,市面上有很多優(yōu)秀的庫,比如:vueuse。

最近我在面試中,喜歡問一道有關(guān)于 hooks 的開放問題:二次封裝一個 loaclStorage 的 hooks 時,需要考慮哪些問題呢?

其實這是一道很簡單的題,只不過想考考面試者在做業(yè)務的時候,會不會考慮更多的邊界情況~接下來說說我對這個問題的小小的理解(可能也不是很全面)。

注意命名,防止污染

比如我現(xiàn)在一個域名下有兩個子項目:

  • A項目
  • B項目

且這兩個項目都需要存儲 userInfo,那要怎么防止這兩組數(shù)據(jù)互相污染呢?所以需要注意命名,在存儲的時候加上對應的項目名前綴,或者其他標識符,保證這組數(shù)據(jù)是唯一的

const PROJECT_NAME = 'test-project'
localStorage.setItem(
  `${PROJECT_NAME}_userInfo`,
  JSON.stringify({ name: 'lsx' })
)

注意版本,迭代防范

請看一個例子,假如我們存儲一段信息,類型是 string

// 存數(shù)據(jù)
const set = () => {
  const info = get()
  if (!info) {
    localStorage.setItem(
      `${PROJECT_NAME}_info`,
      'info_string'
    )
  }
}

// 取數(shù)據(jù)
const get = () => {
  const info = localStorage.getItem(
    `${PROJECT_NAME}_info`
  )
  return info
}

然后項目上線了一段時間,但是這個時候,突然決定要換成 object 類型了,這時候?qū)拇嫒》椒ㄒ沧兞?/p>

// 存數(shù)據(jù)
const set = () => {
  const info = get()
  if (!info) {
    localStorage.setItem(
      `${PROJECT_NAME}_info`,
      JSON.stringify({ name: 'lsx' })
    )
  }
}

// 取數(shù)據(jù)
const get = () => {
  const info = localStorage.getItem(
    `${PROJECT_NAME}_info`
  )
  return JSON.parse(info)
}

但是這樣其實是有隱患的,因為項目已經(jīng)上線了一段時間,有些用戶已經(jīng)存過這個數(shù)據(jù)了,且存的是 string 類型,但是新版本上線之后,取數(shù)據(jù)卻用了 object 的方式去取數(shù)據(jù),這就導致了JSON.parse(字符串)會報錯,影響正常的業(yè)務邏輯~

所以最好是加一個版本號,或者做一下錯誤兼容,這樣就能避免了~

const PROJECT_NAME = 'test-project'
// 每次升級時改變版本號,規(guī)則自己定
const VERSION = 1

// 存數(shù)據(jù)
localStorage.setItem(
  `${PROJECT_NAME}_userInfo_${VERSION}`,
  JSON.stringify({ name: 'lsx' })
)

// 取數(shù)據(jù)
localStorage.getItem(
  `${PROJECT_NAME}_userInfo_${VERSION}`
)

時效性,私密性

時效性,那就是給存進去的數(shù)據(jù)加一個時效,過了某個時間,這個數(shù)據(jù)就時效了,方法就是每次存數(shù)據(jù)進去的時候,加一個時間戳:

// 原來
localStorage.setItem(
  `${PROJECT_NAME}_userInfo`,
  JSON.stringify({ name: 'lsx' })
)

const TIME_OUT = 3 * 60 * 60 * 1000
// 加時間戳
localStorage.setItem(
  `${PROJECT_NAME}_userInfo`,
  JSON.stringify({
    data: { name: 'lsx' },
    // 記錄當前時間
    time: new Date().getTime()
  })
)

// 取數(shù)據(jù)時判斷時間戳
const get = () => {
  let info = localStorage.getItem(
    `${PROJECT_NAME}_userInfo_${VERSION}`
  )
  info = JSON.parse(info)
  const now = new Date().getTime()
  if (now - info.time >= TIME_OUT) {
    localStorage.removeItem(
      `${PROJECT_NAME}_userInfo_${VERSION}`
    )
    return null
  }
  return info
}

有一些數(shù)據(jù)我們不得不存在 localStorage 中,但是又不想被用戶看到,這時候就需要進行加密了(加密規(guī)則自己定):

// 加密函數(shù)
const encrypt = (v) => {}
// 解密函數(shù)
const decrypt = (v) => {}

// 存數(shù)據(jù)
localStorage.setItem(
  `${PROJECT_NAME}_userInfo_${VERSION}`,
  // 加密
  encrypt(JSON.stringify({ name: 'lsx' }))
)

// 取數(shù)據(jù) 解密
decrypt(localStorage.getItem(
  `${PROJECT_NAME}_userInfo_${VERSION}`
))

兼容 SSR

SSR 就是服務端渲染,是在服務端運行代碼,拼接成一個頁面,發(fā)送到瀏覽器去展示出來,所以在服務端是使用不了 localStorage 的,因為不是瀏覽器環(huán)境,所以你像封裝一個比較通用的 localStorage,得兼顧 SSR 的情況:

// 在 SSR 中使用對象替代 localStorage
const SSRStorage = {
  map: {},
  setItem(v) {
    this.map[key] = v
  },
  getItem(key) {
    return this.map[key]
  }
}
let storage = null
// 判斷環(huán)境
if (!window) {
  storage = SSRStorage
} else {
  storage = window.localStorage
}
責任編輯:趙寧寧 來源: 前端之神
相關(guān)推薦

2016-03-02 15:13:54

面試開發(fā)者問題

2022-04-30 18:42:38

Go編程語言

2020-08-06 15:14:07

D語言編程語言

2024-11-05 09:42:59

開發(fā)軟件命令行

2022-01-05 08:56:20

Vue修飾符面試

2024-03-25 11:03:38

Vue修飾符lazy

2012-04-28 09:14:50

編程編程語錄

2021-10-27 14:55:57

Mark TextMarkdown編輯器

2021-01-14 23:14:40

開源Linux生產(chǎn)力應用

2021-11-08 09:18:01

CAS面試場景

2021-12-25 22:31:10

MarkWord面試synchronize

2022-10-17 08:03:47

封裝vue組件

2022-01-03 07:46:36

Linux應用程序操作系統(tǒng)

2021-12-16 18:38:13

面試Synchronize

2021-12-05 21:05:49

前端JSON API

2012-03-30 13:56:17

編程開發(fā)

2021-12-02 18:20:25

算法垃圾回收

2013-10-08 09:34:57

編程漫畫編程漫畫

2014-06-16 13:22:35

點贊
收藏

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

日韩在线观看免费全集电视剧网站| 天天综合色天天| 91久久爱成人| 日韩av男人天堂| 亚洲精品播放| 欧美久久久久久久久中文字幕| 青青草综合在线| 男女视频在线观看免费| 久久成人免费网| 国内精品视频一区| 免费黄色在线网址| 国产在线播放精品| 欧美色电影在线| 精品无码一区二区三区爱欲| 成人高清免费观看mv| 国产麻豆午夜三级精品| 97精品国产97久久久久久春色| 中文字幕 自拍| 亚洲不卡视频| 欧美色图第一页| 欧美一区二区三区爽大粗免费| 幼a在线观看| 26uuu国产在线精品一区二区| 国产综合福利在线| 亚洲综合久久网| 欧美不卡高清| 中文字幕亚洲精品| 亚洲黄色免费在线观看| 国产精品一区二区美女视频免费看 | youjizz在线播放| 成人精品小蝌蚪| 成人黄色影片在线| 99久久久无码国产精品免费蜜柚| 国内精品福利| 色久欧美在线视频观看| 极品粉嫩小仙女高潮喷水久久 | 国产在线一区二区三区四区| 999免费视频| 青青草国产精品97视觉盛宴| 91高潮在线观看| 久一区二区三区| 亚洲视频电影在线| 色噜噜狠狠狠综合曰曰曰| 午夜一区二区三区免费| 凹凸av导航大全精品| 91精品国产色综合久久不卡蜜臀| 亚洲性生活网站| 亚洲精品动漫| 午夜精品久久久| 真实国产乱子伦对白视频| 免费看a在线观看| 亚洲国产精品传媒在线观看| 欧美日韩一区二区三区在线视频| 日本在线一二三| 91香蕉视频mp4| 好吊色欧美一区二区三区视频| 亚洲欧美强伦一区二区| 国产成人av资源| 99在线视频播放| 午夜精品久久久久久久99| 久久精品av麻豆的观看方式| 国产噜噜噜噜久久久久久久久| 无码任你躁久久久久久久| 久久婷婷麻豆| 国产91色在线|| 免费看一级视频| 丝袜亚洲另类丝袜在线| 国产精品激情自拍| 中文字幕在线播放不卡| 久久精品国产久精国产| 亚洲japanese制服美女| 精品国产伦一区二区三| 丁香婷婷深情五月亚洲| 国产在线一区二区三区欧美| 欧美香蕉爽爽人人爽| 国产午夜精品久久久久久免费视 | 色婷婷久久久久swag精品| 国产免费人做人爱午夜视频| 成人不卡视频| 欧美一级午夜免费电影| www.美色吧.com| 日韩av三区| 在线观看日韩av| 亚洲欧美精品aaaaaa片| 一区免费视频| 日本欧美精品在线| 一区二区三区午夜| 粉嫩在线一区二区三区视频| 久久综合伊人77777麻豆| 国产一级片在线| 亚洲视频中文字幕| 一本久道高清无码视频| 欧美成人精品一区二区男人小说| 欧美体内she精视频| 日本中文字幕精品| 麻豆一区一区三区四区| 在线精品国产成人综合| 国产97免费视频| 销魂美女一区二区三区视频在线| 国产精品夜间视频香蕉| 欧日韩在线视频| 中文字幕va一区二区三区| 久久久无码中文字幕久...| 咪咪网在线视频| 欧美另类videos死尸| aa片在线观看视频在线播放| 亚洲91久久| 日本中文字幕久久看| 国产哺乳奶水91在线播放| 26uuu国产日韩综合| 欧美少妇在线观看| 亚洲wwww| 亚洲国产精品免费| 国产免费美女视频| 男人的天堂亚洲| 99精品国产高清一区二区| 二人午夜免费观看在线视频| 亚洲午夜影视影院在线观看| 999在线观看| 色天天色综合| 欧美激情精品久久久久久大尺度| 欧美成人精品网站| 成a人片国产精品| 国产精品亚洲天堂| 日本少妇一区| 亚洲欧美在线x视频| 欧美精品色哟哟| 久久91精品久久久久久秒播| 欧美激情专区| av资源在线| 日韩美女视频在线| 中文字幕无码日韩专区免费| 久久精品亚洲一区二区| 国产一区二区三区色淫影院| 宅男网站在线免费观看| 欧美日韩精品一区二区天天拍小说 | 国产精品51麻豆cm传媒| 北岛玲一区二区三区四区| mm131午夜| 亚洲三级电影| 最近中文字幕mv在线一区二区三区四区 | 中文字幕第66页| 超碰成人久久| 日本不卡视频在线播放| 爽爽视频在线观看| 香蕉久久一区二区不卡无毒影院| 无码人妻aⅴ一区二区三区玉蒲团| 亚洲成av人片一区二区密柚| 国产精品一区二区久久精品| 成人高清在线| 欧美日韩中文精品| 99在线视频免费| 男人的j进女人的j一区| 亚洲视频在线二区| jvid一区二区三区| 亚洲性生活视频| 自拍偷拍福利视频| 国产精品欧美经典| 毛片毛片毛片毛| 99精品一区| 亚洲xxxx做受欧美| 婷婷在线播放| 亚洲精品久久久久久久久久久久久 | 欧洲美女7788成人免费视频| 欧美女同网站| 欧美在线一二三四区| 日韩av片在线免费观看| 精品一区二区三区在线观看| 国产大尺度在线观看| 日韩一二三区| 韩国福利视频一区| 四虎国产精品永远| 欧美色综合网站| 黑人巨大精品一区二区在线| 成人自拍视频在线观看| 日韩av综合在线观看| 国产精品一区二区av日韩在线| 国产精品福利在线观看| av中文字幕在线播放| 精品999在线播放| 91午夜精品亚洲一区二区三区| 亚洲国产精品99久久久久久久久| 亚洲黄色片免费| 亚洲精品婷婷| 亚洲国产一区二区三区在线| 国产一区二区三区精品在线观看| 久久久久中文字幕| 免费在线观看一级毛片| 欧美电影一区二区| 日本高清www免费视频| 中文在线一区二区| 久草福利在线观看| 亚洲在线日韩| 伊甸园精品99久久久久久| 伊色综合久久之综合久久| 欧美中文字幕视频| 国产福利在线播放麻豆| 亚洲欧美国产精品专区久久 | 国产精彩视频在线| 国产日韩视频一区二区三区| 麻豆短视频在线观看| 玖玖国产精品视频| 屁屁影院ccyy国产第一页| 精品国内自产拍在线观看视频 | 亚洲天堂福利av| 最近中文字幕无免费| 精品在线观看视频| 干日本少妇首页| 欧美福利视频| 午夜一区二区三视频在线观看| 懂色av一区二区| 成人精品一区二区三区电影黑人| 精品捆绑调教一区二区三区| 久久久国产一区二区| 久久电影视频| 精品国产一二三| 国产乱人乱偷精品视频| 色综合天天综合网天天狠天天| 欧美成人精品激情在线视频| 国产精品美女久久久久aⅴ国产馆 国产精品美女久久久久av爽李琼 国产精品美女久久久久高潮 | 一级黄色免费毛片| 三级不卡在线观看| 国产伦精品一区二区三区四区视频_| 欧美疯狂party性派对| 快播亚洲色图| 超碰在线成人| 99久久精品久久久久久ai换脸| 日韩综合av| 日韩免费av一区二区| 国产传媒av在线| 欧美日韩国产999| 国产人成网在线播放va免费| 中文字幕无线精品亚洲乱码一区 | 成人免费视频国产| 制服丝袜国产精品| 中文字幕久久熟女蜜桃| 日本高清视频一区二区| 免费黄色av片| 色94色欧美sute亚洲13| 色av性av丰满av| 色综合天天综合网国产成人综合天| 久久精品视频8| 夜夜操天天操亚洲| 玖玖爱免费视频| 一区二区三区在线免费播放| 波多野结衣家庭教师| 亚洲欧美在线aaa| 日本少妇aaa| 中文字幕字幕中文在线中不卡视频| 亚洲图片另类小说| 国产午夜精品福利| 四季av中文字幕| 最新不卡av在线| 亚洲xxxx3d动漫| 亚洲人xxxx| 久久精品国产亚洲AV无码麻豆| 亚洲一区在线观看免费观看电影高清| 久久久久99精品成人片试看| 一区二区三区毛片| 精品无码久久久久| 黄色91在线观看| 手机在线看片1024| 欧美色综合久久| 国产麻豆免费视频| 日韩西西人体444www| www久久久com| 亚洲国模精品一区| 黄色在线免费观看大全| 中文字幕视频在线免费欧美日韩综合在线看 | 国产女人18毛片水真多成人如厕| 亚洲欧美卡通动漫| 亚洲精品日韩综合观看成人91| 久久免费视频99| 欧美日韩国产精品一区二区三区四区| www.国产com| 欧美日韩日日骚| 亚洲成人av综合| 日韩国产中文字幕| www 日韩| 欧美激情国产精品| 国产综合色区在线观看| 成人黄色网免费| 日韩精品福利一区二区三区| 五月婷婷一区| 亚洲午夜精品久久久久久app| 成人观看免费完整观看| 另类小说一区二区三区| 中文字幕乱码在线人视频| 91日韩在线专区| www.99re6| 欧美日韩免费观看中文| 一区二区三区亚洲视频| 亚洲国产精品va在线| 国产毛片av在线| 欧美激情精品久久久久久免费印度| 欧美羞羞视频| 粉嫩精品一区二区三区在线观看| 天海翼精品一区二区三区| 中文字幕一区二区三区有限公司| 亚洲精品色图| 亚洲综合在线一区二区| 久久精品人人爽人人爽| 精品无码免费视频| 欧美日韩一区精品| 天堂中文在线资源| 久久久999精品视频| 亚洲黄色中文字幕| 成人免费在线看片| 欧美电影三区| 免费在线观看的毛片| 成人妖精视频yjsp地址| 国产aaaaaaaaa| 福利视频第一区| www五月婷婷| 久久精品电影网| 韩国精品主播一区二区在线观看| 国产精品theporn88| 婷婷精品进入| 国产精品久久a| 久久先锋影音av| 国产精品美女毛片真酒店| 91精品一区二区三区久久久久久| 国产一级在线| 日韩av不卡电影| 天海翼亚洲一区二区三区| 国产91沈先生在线播放| 精品一区二区成人精品| 丰满的亚洲女人毛茸茸| 欧美日韩另类字幕中文| 天堂在线资源库| 午夜精品一区二区三区在线| 91精品啪在线观看国产爱臀| 特色特色大片在线| 久久成人免费网站| 黄色免费一级视频| 在线区一区二视频| 黄色在线网站| 国产精品国产三级国产aⅴ9色 | 日本韩国欧美中文字幕| 精品国产一区a| ririsao久久精品一区| 国产91aaa| 激情欧美日韩一区| 国产欧美视频一区| 亚洲综合免费观看高清完整版| 国产欧美综合视频| 久久国产加勒比精品无码| 亚洲一区二区小说| 992tv成人免费观看| 国产一区二区三区免费观看| 日本中文字幕免费在线观看| 91精品国产欧美一区二区| 国产1区在线| 97在线资源站| 亚洲欧洲一区| 37p粉嫩大胆色噜噜噜| 色婷婷综合久久久中文一区二区 | 在线免费看av的网站| 中文字幕欧美日韩在线| 91麻豆精品一二三区在线| 中文字幕中文字幕在线中心一区| 国产一区二区三区蝌蚪| 久久老司机精品视频| 亚洲第一天堂无码专区| 捆绑调教日本一区二区三区| 欧美aaaaa喷水| 免费不卡在线观看| 三级在线观看免费大全| 日韩欧美你懂的| 色戒汤唯在线观看| 婷婷久久青草热一区二区 | 3p在线观看| 亚洲一区二区三区乱码aⅴ蜜桃女| 红桃视频欧美| caopeng视频| 欧美精品丝袜中出| 大香伊人久久| 青青草原成人| 国产一区二区三区av电影 | 一本色道久久综合| 级毛片内射视频| 日韩午夜激情视频| 芒果视频成人app| 国产经典久久久| 26uuu成人网一区二区三区| 在线观看色网站| 国内外成人免费激情在线视频网站| 亚洲最大在线| 免费不卡av网站| 色狠狠一区二区| 深夜国产在线播放| 日韩和欧美的一区二区| 国产高清成人在线| 亚洲婷婷久久综合| 久久久久久欧美| 色狮一区二区三区四区视频| 青青草视频网站| 在线电影院国产精品| av日韩电影| 黄色一级片黄色|