開發(fā)客戶端時(shí)常會(huì)用到一些非永久緩存的需求,而微信緩存只能按key永久緩存;其次,當(dāng)讀取緩存失敗時(shí),有時(shí)需要給個(gè)默認(rèn)值,所以得二次判斷下,今天想了一下何不封裝一個(gè)緩存框架。 ...
開發(fā)客戶端時(shí)常會(huì)用到一些非永久緩存的需求,而微信緩存只能按key永久緩存;其次,當(dāng)讀取緩存失敗時(shí),有時(shí)需要給個(gè)默認(rèn)值,所以得二次判斷下,今天想了一下何不封裝一個(gè)緩存框架。
put(k, v, t)
k為key,v為具體內(nèi)容(支持字符串、json、數(shù)組、boolean等等),t為可選參數(shù)表示有效時(shí)間(單位:秒)
如存儲(chǔ)k為123過期時(shí)間1秒,則調(diào)用put('k', '123', 1)方法;若永久存儲(chǔ)調(diào)用put('k', '123')
永久保存json:put('k', {"a":"1"}),數(shù)組、boolean等同理。
get(k, def)
k為key,def為可選參數(shù),表示無緩存數(shù)據(jù)時(shí)返回值(支持字符串、json、數(shù)組、boolean等等)
如讀取k緩存,則調(diào)用get('k');若想要無緩存時(shí),返回默認(rèn)值則get('k','默認(rèn)值'),支持各個(gè)數(shù)據(jù)類型。
remove(k)
移除某個(gè)key
clear()
清空所有key
其他方法
使用wx原生的即可。
put(k, v, t)
function put(k, v, t) {
// console.log(k);
wx.setStorageSync(k, v)
var seconds = parseInt(t);
if (seconds > 0) {
var timestamp = Date.parse(new Date());
timestamp = timestamp / 1000 + seconds;
// console.log(timestamp);
wx.setStorageSync(k + postfix, timestamp + "")
} else {
wx.removeStorageSync(k + postfix)
}
}
先存儲(chǔ)key的數(shù)據(jù)(字符串、數(shù)組、json),再判斷過期時(shí)間是否大于0,當(dāng)大于0時(shí),存儲(chǔ)key+一個(gè)后綴,內(nèi)容為當(dāng)前時(shí)間戳(單位秒)+有效時(shí)間t。
get(k, def)
function get(k, def) {
var deadtime = parseInt(wx.getStorageSync(k + postfix))
if (deadtime) {
if (parseInt(deadtime) < Date.parse(new Date()) / 1000) {
if (def) { return def; } else { return; }
}
}
var res = wx.getStorageSync(k);
if (res) {
return res;
} else {
return def;
}
}
get方法,先通過key+一個(gè)后綴得到時(shí)間戳,如果時(shí)間戳存在,切小于當(dāng)前時(shí)間,說明過期;【那么,當(dāng)有默認(rèn)值時(shí)返回默認(rèn)值(包含字符串、數(shù)組、json),否則返回空?!慨?dāng)沒過期時(shí),正常讀取key的內(nèi)容,key存在時(shí)正常返回;否則返回默認(rèn)值,當(dāng)不存在默認(rèn)值時(shí)返回空。
其他方法
function remove(k) {
wx.removeStorageSync(k);
wx.removeStorageSync(k + postfix);
}
function clear() {
wx.clearStorageSync();
}
remove(k)需要移除2個(gè)key,因?yàn)榇鎯?chǔ)的時(shí)候,可能存了時(shí)間戳,當(dāng)然即使不存在key,移除也是不會(huì)報(bào)錯(cuò)的。
下載src文件夾內(nèi)wCache.js文件 需要使用的js文件頭加入var wc = require('../../src/wcache.js')。 var s=wc.get('k', '你好')、wc.put('k', 'string你好啊')等; 使用例子
get(e) {
this.setData({
text: null
});
switch (e.currentTarget.dataset.type) {
case "def":
this.setData({
text: wc.get('k')
});
break;
case "string":
this.setData({
text: wc.get('k', '你好')
});
break;
case "json":
this.setData({
text: wc.get('k', { "a": "1" })
});
break;
}
}
put(e) {
console.log(e);
switch (e.currentTarget.dataset.type) {
case "string":
wc.put('k', 'string你好啊');
break;
case "json":
wc.put('k', { "b": "3" }, 2);
break;
case "list":
wc.put('k', [1, 2, 3]);
break;
case "boolean":
wc.put('k', true);
break;
}
wx.showToast({
title: '存儲(chǔ)成功',
duration: 500,
})
}
工作日 8:30-12:00 14:30-18:00
周六及部分節(jié)假日提供值班服務(wù)