在微信小程序中,并没有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)
})
}
})
}
这是实现缓存时效性的代码段,仅供参考。