注冊登錄

優(yōu)化小程序自身的Storage

2018-09-28
導(dǎo)讀:1、小程序中的存儲只有 Storage ,特性如下: 上限為 10MB 以用戶緯度隔離,同一個設(shè)備, A 無法訪問 B 用戶的數(shù)據(jù)。 持久緩存,只有在用戶關(guān)掉小程序才會刪除,如果空間不足,會進行...

1、小程序中的存儲只有 Storage ,特性如下:

 

  1. 上限為 10MB
  2. 以用戶緯度隔離,同一個設(shè)備,A 無法訪問 B 用戶的數(shù)據(jù)。
  3. 持久緩存,只有在用戶關(guān)掉小程序才會刪除,如果空間不足,會進行 LRU ,也就是不經(jīng)常使用的小程序的數(shù)據(jù)緩存區(qū)域會被全部清空。
  4. 在體驗版、開發(fā)版、和線上版都共用一套,并不會隔離。
  5. 沒有 Cookie

2、因此我們要在 Storage 中隔離一個 Cookie ,用來模擬瀏覽器中的 Cookie ,解析接口返回的 Header,設(shè)置 Cookie,在發(fā)送接口請求前,自動帶上 Cookie。

從上面知道,storage 不會自動銷毀,而是在小程序銷毀的時候再銷毀。我們先了解一下小程序的運行機制。

小程序運行機制:

小程序沒有重啟的概念  當(dāng)小程序進入后臺,客戶端會維持一段時間的運行狀態(tài),超過一定時間后(目前是5分鐘)會被微信主動銷毀  置頂?shù)男〕绦虿粫晃⑿胖鲃愉N毀  當(dāng)收到系統(tǒng)內(nèi)存告警也會進行小程序的銷毀

代碼實現(xiàn):

 

  1. const storage = {
  2. set(){}, //設(shè)置緩存
  3. get(){}, //獲取緩存
  4. remove(){}, // 移除緩存
  5. checkAndClearExpired(){}, //將過期緩存清理掉
  6.   isExpired() {} //判斷是否過期
  7. }

在 storage 中隔離一個字段,用來做 cookie

 

  1. let cookie = (function(){
  2. return wx.getStorageSync('cookies');
  3. }())
  4. const Cooke = {
  5. getCookie(){}, //從內(nèi)存中獲取cookie
  6. setCookie(){}, // 設(shè)置cookie
  7. setCookieInHeader(){}, //根據(jù)response的Header設(shè)置cookie
  8. removeCookie() {}, //刪除cookie
  9. isExpired() {} //判斷是否過期
  10. }

在設(shè)置storage的時候,增加一個字段 expire 用來表示過期時間。簡化代碼如下:

 

  1. function isExpired (expires) {
  2. // 小于等于現(xiàn)在時間為過期
  3. if (new Date(expires) <= new Date()) {
  4. return true;
  5. }
  6. }

 

重磅推薦:小程序開店目錄

第一部分:小商店是什么

第二部分:如何開通一個小商店

第三部分:如何登錄小商店

第四部分:開店任務(wù)常見問題

第五部分:小商店可以賣什么

第六部分:HiShop小程序特色功能

第七部分:小程序直播

第八部分:小程序收貨/物流

第九部分:小程序怎么結(jié)算

第十部分:小程序客服

第十一部分:電商創(chuàng)業(yè)

第十二部分:小程序游戲開發(fā)

電話咨詢 微信咨詢 預(yù)約演示 0元開店