同时存多个变量缓存 微信小程序_「小程序JAVA实战」小程序数据缓存API(54)...

本文介绍了微信小程序的数据缓存方法,包括异步和同步的缓存操作,建议在开发中优先使用同步方法,以避免UI卡顿和调试难度。内容涵盖了wx.getStorage、wx.setStorage等系列API,强调在特定业务需求下选择异步操作,并提供了更改用户存储方法使用缓存的示例。
摘要由CSDN通过智能技术生成

f83146d64b29ed24c3a083081f5d093c.png
刚开始写小程序的时候,用户信息我是按照app.js增加全局变量的方式来做的,后来当看到搜索插件可以保存上次的搜索内容,让我知道了原来小程序还有缓存的API,来一起了解下。源码https://github.com/limingios/wxProgram.git 中No.15

数据缓存

  • 官方网址
    >https://developers.weixin.qq.com/miniprogram/dev/api/storage/wx.getStorage.html

36612ce5eae16d676fdff092b9da2992.png
  • 发现一个问题
    >所有的缓存方法都有异步和同步,有老铁肯定有疑问,我来解答看我分析的对不?在微信小程序的开发中,缓存会用到如下的几个方法,分别对应一个同步和异步的方法,最大上限是10MB。在涉及到缓存的时候,一般我们建议用同步的写法,异步的写法其实是一种非常危险的写法,第一点,它会让代码变得难以阅读,第二点,它会引起许多未知的错误,如果对异步的方法不是很熟悉,建议能用同步就用同步,千万不要用异步,当然小程序里面有些情况是必须用异步的,但是在小程序里面用到异步的情况会非常的少,同步的缺陷是什么呢?方法执行很慢的时候整个UI会卡住,同步的方法运行不过去,后面的方法就走不了,所以呢,代码的耗时就会非常长,这是同步的缺点。那么异步的好处呢,代码会立刻走完,然后获取到缓存以后,由框架再去调用success,整个流程会很快的走完,不会让UI有停滞的效果,这是异步的一个优势。般建议该用同步的时候就要用同步,同步解决不了的问题再用异步,我们都知道异步方法的调试有点困难,这也是我们不建议用异步的原因。当然这个也要根据自己的业务来进行判断看是否用同步还是异步,当你的业务需要解耦的情况下,去使用异步,当你的业务是同步的话,那就最好还是使用同步,也就是说异步的操作是需要业务的配合来设计的,小程序的缓存上限是10MB,你试想一下子提取10MB的数据出来,会是什么样的情况,那这个时候你就要考虑异步的情况了。因为它整个的过程有可能很慢,给用户的体验也非常不好,但是我觉得这一种情况应该非常少。

介绍缓存方法

  • wx.getStorage(Object object)
    >从本地缓存中异步获取指定 key 的内容

https://developers.weixin.qq.com/miniprogram/dev/api/storage/wx.getStorage.html

31d45059aa9e767b0b127ce7424685d3.png
  • wx.getStorageSync(string key)
    >wx.getStorage 的同步版本

228b8e0f9fe75c0c35b13adda60aa958.png
  • wx.setStorage(Object object)
    >将数据存储在本地缓存中指定的 key 中,会覆盖掉原来该 key 对应的内容。

https://developers.weixin.qq.com/miniprogram/dev/api/storage/wx.setStorage.html

aa6b6cb9e2331854a29acdcbe408aa21.png
  • wx.setStorageSync(string key, Object|string data)
    >wx.setStorage 的同步版本

a80ad924c112b200f83aa5656baee1ff.png
  • wx.removeStorage(Object object)
    >从本地缓存中移除指定 key

56f962fc8e2264078ebaad9d1562605f.png

a2afdb787eb4be45b61fd6d1fed08b81.png
  • wx.removeStorageSync(string key)
    >wx.removeStorage 的同步版本

14536b497ea8a579a16b3060b9cdf90a.png
  • wx.clearStorage(Object object)
    >清理本地数据缓存

ba0ebda1784e725a67abf3a696260a58.png
  • wx.clearStorageSync()
    >wx.clearStorage 的同步版本

a3c1544fbe0729902db535858218a322.png
  • wx.getStorageInfo(Object object)
    >异步获取当前storage的相关信息

f0625da850b36f892fdc4754b8def9a9.png
  • Object wx.getStorageInfoSync()
    >wx.getStorageInfo 的同步版本

c7d2a5cde3e8eb2a3546b96f33d479c5.png

更改现有的用户存储方法使用缓存

  • app.js 修改
//app.js
App({
  serverUrl:"http://127.0.0.1:8081/",
  userInfo:null,
  setGlobalUserInfo:function(user){
    wx.setStorageSync("userInfo", user);
  },
  getGlobalUserInfo: function () {
    return wx.getStorageSync("userInfo");
  }
})
  • app.js 修改
    >原来的userInfo赋值和取值都改成从缓存中取到。

905d50a3719c766108044330bfd00ff1.png

PS:通过缓存的时候进行控制,更方便。如果是全局变量的话肯定没有缓存方便。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值