注册登录

优化小程序自身的Storage

2018-09-28
导读:1、小程序中的存储只有 Storage ,特性如下: 上限为 10MB 以用户纬度隔离,同一个设备, A 无法访问 B 用户的数据。 持久缓存,只有在用户关掉小程序才会删除,如果空间不足,会进行...

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

 

  1. 上限为 10MB
  2. 以用户纬度隔离,同一个设备,A 无法访问 B 用户的数据。
  3. 持久缓存,只有在用户关掉小程序才会删除,如果空间不足,会进行 LRU ,也就是不经常使用的小程序的数据缓存区域会被全部清空。
  4. 在体验版、开发版、和线上版都共用一套,并不会隔离。
  5. 没有 Cookie

2、因此我们要在 Storage 中隔离一个 Cookie ,用来模拟浏览器中的 Cookie ,解析接口返回的 Header,设置 Cookie,在发送接口请求前,自动带上 Cookie。

从上面知道,storage 不会自动销毁,而是在小程序销毁的时候再销毁。我们先了解一下小程序的运行机制。

小程序运行机制:

小程序没有重启的概念  当小程序进入后台,客户端会维持一段时间的运行状态,超过一定时间后(目前是5分钟)会被微信主动销毁  置顶的小程序不会被微信主动销毁  当收到系统内存告警也会进行小程序的销毁

代码实现:

 

  1. const storage = {
  2. set(){}, //设置缓存
  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(){}, //从内存中获取cookie
  6. setCookie(){}, // 设置cookie
  7. setCookieInHeader(){}, //根据response的Header设置cookie
  8. removeCookie() {}, //删除cookie
  9. isExpired() {} //判断是否过期
  10. }

在设置storage的时候,增加一个字段 expire 用来表示过期时间。简化代码如下:

 

  1. function isExpired (expires) {
  2. // 小于等于现在时间为过期
  3. if (new Date(expires) <= new Date()) {
  4. return true;
  5. }
  6. }

 

重磅推荐:小程序开店目录

第一部分:小商店是什么

第二部分:如何开通一个小商店

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

第四部分:开店任务常见问题

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

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

第七部分:小程序直播

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

第九部分:小程序怎么结算

第十部分:小程序客服

第十一部分:电商创业

第十二部分:小程序游戏开发

电话咨询 微信咨询 预约演示 0元开店