因為我們的系統設計 所有的數據查詢全部是采用參數化json 后台解析后進行數據返回
由於使用統一的數據查詢入口 所有可以很方便的為數據設置緩存
var ModelDataCache = new Array();
//根據搜索模型獲取緩存
function GetDataCache(whereStr) {
var data= $.grep(ModelDataCache, function (value) {
return value.whereStr == whereStr && new Date() - value.addTime < 60000;
})
if (NoNull(data)) {
return data[0].Data;
} else {
return null;
}
}
//根據搜索模型設置緩存
function SetDataCache(whereStr, Data) {
for (var i = 0; i < ModelDataCache.length; i++) {
if (ModelDataCache[i].whereStr == whereStr) {
ModelDataCache[i].Data = Data;
ModelDataCache[i].addTime = new Data();
return;
}
}
ModelDataCache.push({
"whereStr": whereStr,
"Data": Data,
"addTime": new Date()
});
}
//統一的異步請求接口 每當請求該接口時 清空緩存
function agAjax(url, type, data) {
// url='/Agent.ashx?urlstr=http://192.168.31.99:99/'+url;
var ajaxData = null;
$.ajax({
type: type,
async: false,
url: url,
data: data,
dataType: 'json',
success: function (data) {
if (data.state != 'success') {
tips(data.content);
}
ajaxData = data;
},
error: function () {
}
});
ModelDataCache = new Array();
return ajaxData;
}
