在微信小程序中,并没有cookie机制,只有本地缓存功能。
每个微信小程序都可以有自己的本地缓存,可以通过 wx.setStorage(wx.setStorageSync)、wx.getStorage(wx.getStorageSync)、wx.clearStorage(wx.clearStorageSync)可以对本地缓存进行设置、获取和清理。同一个微信用户,同一个小程序 storage 上限为 10MB。localStorage 以用户维度隔离,同一台设备上,A 用户无法读取到 B 用户的数据。由此可以看出,小程序的缓存除非是用官方清空缓存或者一些不确定因素清空缓存,不然缓存会永久存在,这对有些缓存数据需要时效性带来麻烦了。
注意: 如果用户储存空间不足,我们会清空最近最久未使用的小程序的本地缓存。我们不建议将关键信息全部存在 localStorage,以防储存空间不足或用户换设备的情况。(官方传送门)
我的解决方法是在对数据进行缓存的时候,顺便把当前时间也进行缓存,而在取数据的时候先要对缓存时间与现在时间相比,看是否是在自己需要时效时间内,如果在时效时间内则取缓存数据;否则更新数据。
export const getWYResourcesList = () => {return new Promise((resolve, reject) => {
let App = getApp()
let timestamp = Date.parse(new Date());
let resourcesList = getStorage('resourcesList');
let timestampCache = getStorage('resourcesListCache');
if ((timestamp - timestampCache) > cacheTime) {
console.log('过期了');
resourcesList = '';
}if (resourcesList) {
resolve(resourcesList)
} else {
wx.showLoading()
ajax({
url: '/api/admin/resources/create',
headers: headers(1)
}).then(res => {
wx.hideLoading()
resolve(res.result)
setStorage('resourcesList', res.result);
setStorage('resourcesListCache', timestamp)}).catch(e => {
reject(e)
})
}})
}
【如何实现微信小程序wx.setStorage数据缓存实现缓存过期时间】这是实现缓存时效性的代码段,仅供参考。
推荐阅读
- 微信小程序地址位置定位wx.getLocation 4G 与WIFI 不一致
- C#|微信小程序开发系列(六)——“处理请求时出错”怎么处理()
- 微信小程序|微信小程序从入门到入土教程(02)
- 微信小程序开发项目实战(五)
- 微信小程序前端请求云函数显示超时错误
- wepy|wepy微信小程序swiper组件设置自适应图片高度,图片高度不一致取最高图片的高度
- 解决实际问题|小程序部署环境问题
- 小程序之云开发初体验
- 微信小程序中获取时间戳IOS不兼容