# 數(shù)據(jù)緩存+圖片緩存
> 引自tcld2269
## **demo下載地址**:http://pan.baidu.com/s/1i5JqPFZ
* * * * *
> 設(shè)計(jì)思路:1.先從本地文件讀取數(shù)據(jù),如果讀取到則直接返回
2.如果本地沒(méi)有緩存,則前往服務(wù)器取數(shù)據(jù),然后存到本地
3.如果本地緩存過(guò)期(服務(wù)器端數(shù)據(jù)進(jìn)行了更新),則更新本地緩存文件
* * * * *
> 1.通用js,存放在common.js,每個(gè)頁(yè)面都要引用。
var serverurl = "http://xxx.xxx.com/appservice.asmx";//服務(wù)器接口路徑
var machineurl = "http://xxx.xxx.com";//服務(wù)器路徑,用于圖片顯示
~~~
//緩存方法
function doCache(folder, id, url, callback) {
readFile('/' + folder + '/' + id + '.json', function(ret, err) {
if (ret.status) {
//如果成功,說(shuō)明有本地存儲(chǔ),讀取時(shí)轉(zhuǎn)換下數(shù)據(jù)格式
//拼裝json代碼
//alert('取到緩存')
var cacheData = ret.data;
callback(JSON.parse(cacheData));
iCache($('.cache'));
//再遠(yuǎn)程取一下數(shù)據(jù),防止有更新
ajaxRequest(url, 'GET', '', function(ret, err) {
if (ret) {
if (cacheData != JSON.stringify(ret)) {
//有更新處理返回?cái)?shù)據(jù)
//alert('更新緩存')
callback(ret);
//緩存數(shù)據(jù)
writeFile(ret, id, folder);
iCache($('.cache'));
}
} else {
alert('數(shù)據(jù)獲取失?。?#039;);
}
})
} else {
//如果失敗則從服務(wù)器讀取,利用上面的那個(gè)ajaxRequest方法從服務(wù)器GET數(shù)據(jù)
ajaxRequest(url, 'GET', '', function(ret, err) {
if (ret) {
//處理返回?cái)?shù)據(jù)
//alert('沒(méi)取到緩存')
callback(ret);
//緩存數(shù)據(jù)
writeFile(ret, id, folder);
iCache($('.cache'));
} else {
alert('數(shù)據(jù)獲取失敗!');
}
})
}
})
}
//ajax請(qǐng)求
function ajaxRequest(url, method, datas, callBack) {
var serverUrl = serverurl;
var now = Date.now();
api.ajax({
url : serverUrl + url,
method : method,
cache : false,
timeout : 30,
dataType : 'json',
data : {
values : datas
}
}, function(ret, err) {
if (ret) {
callBack(ret, err);
} else {
api.alert({
msg : ('錯(cuò)誤碼:' + err.code + ';錯(cuò)誤信息:' + err.msg + '網(wǎng)絡(luò)狀態(tài)碼:' + err.statusCode)
});
}
});
}
//讀文件
function readFile(path, callBack) {
var cacheDir = api.cacheDir;
api.readFile({
path : cacheDir + path
}, function(ret, err) {
callBack(ret, err);
});
}
//寫文件
function writeFile(json, id, path) {
//緩存目錄
var cacheDir = api.cacheDir;
api.writeFile({
//保存路徑
path : cacheDir + '/' + path + '/' + id + '.json',
//保存數(shù)據(jù),記得轉(zhuǎn)換格式
data : JSON.stringify(json)
}, function(ret, err) {
})
}
//緩存圖片
function iCache(selector) {
selector.each(function(data) {! function(data) {
var url = selector.eq(data).attr("src");
var img = this;
var pos = url.lastIndexOf("/");
var filename = url.substring(pos + 1);
var path = api.cacheDir + "/pic/" + filename;
var obj = api.require('fs');
obj.exist({
path : path
}, function(ret, err) {
//msg(ret);
if (ret.exist) {
if (ret.directory) {
//api.alert({msg:'該路徑指向一個(gè)文件夾'});
} else {
//api.alert({msg:'該路徑指向一個(gè)文件'});
//selector.eq(data).src=path;
selector.eq(data).attr('src', null);
path = api.cacheDir + "/pic/" + filename;
selector.eq(data).attr('src', path);
//console.log(selector.eq(data).attr("src"));
}
} else {
api.download({
url : url,
savePath : path,
report : false,
cache : true,
allowResume : true
}, function(ret, err) {
//msg(ret);
if (ret) {
var value = ('文件大?。?#039; + ret.fileSize + ';下載進(jìn)度:' + ret.percent + ';下載狀態(tài)' + ret.state + '存儲(chǔ)路徑: ' + ret.savePath);
} else {
var value = err.msg;
};
});
}
});
}(data);
});
};
~~~
> 2.調(diào)用方法。
~~~
//緩存ID
var id = api.pageParam.typeId;
//緩存目錄,存儲(chǔ)地址為 Caches/folder/id.json
var folder = "cartype";
//請(qǐng)求地址
var url = "/getCategoryByParentId?parentId=" + id + "&key=" + key;
//讀取執(zhí)行
doCache(folder, id, url, function(data) {
//處理拼接html
//圖片樣式加上cache
});
~~~
* * * * *
> 3.圖片緩存的實(shí)現(xiàn)。
~~~
在需要圖片緩存的頁(yè)面,加上<script src="../../js/zepto.min.js"></script>
然后在doCache回調(diào)里面的圖片的class加上cache即可自動(dòng)實(shí)現(xiàn)圖片緩存
~~~
### **備注:需要云模塊中添加fs文件模塊。**
* * * * *
* * * * *
# 上劃翻頁(yè)的實(shí)現(xiàn)
> 自動(dòng)加載下10條,沒(méi)有數(shù)據(jù)的話就顯示暫無(wú)內(nèi)容。頁(yè)數(shù)為0的話是用的緩存讀取數(shù)據(jù),保證了第一次的加載速度。
由于也用到了上面的緩存,所以也需要引用common.js和zepto.min.js
### 1)在apiready中定義當(dāng)前頁(yè)碼
~~~
$api.setStorage("resou_index", 0);
load();
//上拉翻頁(yè)
api.addEventListener({
name : 'scrolltobottom'
}, function(ret, err) {
$api.setStorage("resou_index", $api.getStorage("resou_index") - 0 + 1);
load();
});
~~~
### 2)數(shù)據(jù)加載方法
~~~
//數(shù)據(jù)加載,first是判斷是否重新刷新,index2是傳入的當(dāng)前頁(yè)碼
function load(first, index2) {
var index = $api.getStorage("resou_index");
if (index2 != null) {
index = index2;
}
var id = "resou";
var url = "/getGoodsTagList?tag=" + id + "&pageIndex=" + index + "&pageCount=20&key=" + key;
if (index == 0) {
//默認(rèn)加載緩存
var folder = "getGoodsTagList";
doCache(folder, id, url, function(data) {
dealWithHtml(data, first, index);
});
} else {
//分頁(yè)后不加載緩存
ajaxRequest(url, 'get', '', function(data) {
dealWithHtml(data, first, index);
});
}
}
~~~
### 3)處理回調(diào)數(shù)據(jù)
> 可以使用doT模板
~~~
function dealWithHtml(data, first, index) {
//處理數(shù)據(jù)html的拼接
}
~~~
- 關(guān)于我們
- ApiCloud
- 支付模塊
- 微信支付--wxPay(客戶端)
- 微信支付--wxPay(服務(wù)端)
- 支付寶支付--aliPay(客戶端配置)
- 支付寶支付--aliPay(服務(wù)端配置)
- DoT模板
- 緩存模塊
- 監(jiān)聽模塊
- 百度定位模塊
- 設(shè)置狀態(tài)欄字體顏色
- 選擇城市插件
- 跨頁(yè)面執(zhí)行方法
- 安卓-點(diǎn)擊返回事件
- 上傳圖片模塊
- 點(diǎn)擊彈出放大圖片層
- 魅族手機(jī)apiready問(wèn)題
- 分享
- 跨win或frm執(zhí)行腳本
- 關(guān)于ios數(shù)字自動(dòng)識(shí)別成手機(jī)號(hào)
- 百度地圖bMap
- 語(yǔ)音識(shí)別模塊
- tabBarMenu底部導(dǎo)航
- 第三方登錄
- QQ網(wǎng)站和appQQ賬號(hào)的統(tǒng)一問(wèn)題解決
- 微信登錄
- QQ登錄
- 微博登錄
- 上拉加載、下拉刷新模塊
- 圖片緩存
- 文件和圖片緩存機(jī)制分享
- PHP
- 支付寶及時(shí)到賬
- no input file specified報(bào)錯(cuò)解決
- thinkphp 整合kindeditor
- 整合tpshop微信模塊到thinkcmf中
- thinkphp3.1.3整合支付寶
- 網(wǎng)站接入QQ OAuth2.0登錄教程
- ThinkPHP整合百度編輯器Ueditor
- PHP加快執(zhí)行效率的寫法規(guī)范
- ThinkPHP操作大全
- PHP操作大全
- Thinkphp中SQL操作返回值
- php5.3 foreach 使用&(與運(yùn)算符)引用賦值要注意的問(wèn)題
- mysql給字段追加值
- 阿里大魚短信平臺(tái)接入
- Navicat 導(dǎo)出 Mysql 數(shù)據(jù)字典
- php 面向?qū)ο笕娼坛?/a>
- PHP5下調(diào)用SOAP
- PHP處理時(shí)間格式添加空格
- 偽裝URL請(qǐng)求(.htaccess)
- url請(qǐng)求參數(shù)加解密
- JS插件
- artDialog彈窗-頁(yè)面?zhèn)髦?/a>
- jQuery點(diǎn)擊遮罩彈出層固定居中
- jeBox原生彈窗
- bxslider輪播
- js生成指定位數(shù)隨機(jī)數(shù)
- 發(fā)送短信倒計(jì)時(shí)
- js調(diào)試
- jQuery.validator 表單驗(yàn)證規(guī)則
- Swiper 輪播
- 獲得焦點(diǎn)時(shí)-圖片抖動(dòng)
- uploadify無(wú)刷新上傳圖片
- 導(dǎo)航下拉隱藏上拉顯示
- 獲得焦點(diǎn)時(shí)-加黑色蒙版
- jquery.qrcode.js生成二維條形碼(支持中文)
- jquery.qrcode.js生成二維條形碼(官方不支持中文)
- nth-child 選擇器
- 無(wú)刷新點(diǎn)擊實(shí)現(xiàn)加載更多數(shù)據(jù)
- 刷新頁(yè)面方法
- 判斷滾動(dòng)條向上向下
- 跨瀏覽器復(fù)制jQuery-zclip
- js校驗(yàn)表單后提交表單的三種方法
- 用JS判斷下拉框是否選中
- div中滾動(dòng)
- 提交時(shí)彈出模態(tài)框
- 當(dāng)圖片不顯示時(shí)替換方法
- 前端
- CSS3
- HTML5
- css技巧
- 移動(dòng)端rem
- Flex布局
- 電商詳情滾動(dòng)條監(jiān)聽
- VueCircleMenu圓環(huán)按鈕
- iframe自適應(yīng)頁(yè)面高度
- 百度Echart
- input:radio改變選中顏色
- Jquery
- 響應(yīng)式布局基本實(shí)現(xiàn)Media Query
- 循環(huán)輸出只輸出新內(nèi)容
- 小程序
- wx.request坑
- 概要
- git操作
- 本地記住密碼
- 操作
- 生成ssh公鑰 記住密碼
- git避坑
- ES6學(xué)習(xí)手札
- 調(diào)試小插件
- 谷歌插件Postman
- PHP調(diào)試助手
- WordPress
- 緩存服務(wù)器Redis
- 在線代碼運(yùn)行 Docker
- 在ubuntu下怎樣安裝https
- BrowserSync 瀏覽器同步測(cè)試工具
- getmarkman高效的設(shè)計(jì)稿標(biāo)注、測(cè)量工具
- PHPstrom軟件
- 服務(wù)器
- linux 安裝搭建服務(wù)器配置及nginx配置
- tpshop的nginx 服務(wù)器配置方法
- (服務(wù)器訪問(wèn)文件404解決辦法)IIS 之 添加MIME擴(kuò)展類型及常用的MIME類型列表
- mysql部分
- mysql緩存
- MySql監(jiān)控工具--mytop
- MySql主從搭建
- mysql優(yōu)化
- Mysql 復(fù)制 (主從復(fù)制)
- iOS開發(fā)筆記 - 上線流程
- VUE避坑指南
- 從零開始學(xué)Vue
- Vue-cli
- Webpack
- VUE小記
- npm打包空白
- 打包背景圖片/項(xiàng)目圖片不顯示
- VUE避坑指南/elementUI upload 自定義http-request上傳
- 關(guān)于watch監(jiān)聽路由重復(fù)加載方法
- 解決加載內(nèi)容的時(shí)候閃動(dòng)問(wèn)題
- vuecli沒(méi)有network訪問(wèn)地址
- python學(xué)習(xí)
- python初始
- pytho內(nèi)置函數(shù)大全
- win10 播放器播放TS文件問(wèn)題
- 設(shè)計(jì)網(wǎng)站
- VUE避坑指南/VUE-CLI部署空白
- swiper使用問(wèn)題
- uni-app學(xué)習(xí)手冊(cè)
- 目錄結(jié)構(gòu)
- layUI
- nodesass版本sassloader版本問(wèn)題
