分享者:kingrome2017,來自原文地址
上篇:
前言
頁面緩存的設(shè)置優(yōu)化了頁面加載,減少了頻繁的調(diào)取接口,使用戶在斷網(wǎng)的情況下有更好的體驗(yàn)。
每個(gè)微信小程序都可以有自己的本地緩存,可以通過 wx.setStorage(wx.setStorageSync)、wx.getStorage(wx.getStorageSync)、wx.clearStorage(wx.clearStorageSync)可以對(duì)本地緩存進(jìn)行設(shè)置、獲取和清理。本地緩存最大為10MB。
注意: localStorage 是永久存儲(chǔ)的,但是我們不建議將關(guān)鍵信息全部存在 localStorage,以防用戶換設(shè)備的情況。
項(xiàng)目需求
通過使用scroll-view 自定義的鼠標(biāo)滾動(dòng)事件onscrollLower,監(jiān)聽頁面下拉事件
page.init()的方法里封裝了請(qǐng)求數(shù)據(jù)的接口,后臺(tái)api文檔自帶分頁pageSize,默認(rèn)值為10,-1為請(qǐng)求全部數(shù)據(jù)。
說明:
觸發(fā)下滑事件通過與頁面data緩存數(shù)據(jù)對(duì)比,去請(qǐng)求接口。
代碼實(shí)現(xiàn)
-
var n=0
-
page.init = function(callback) {
-
page.data.loading = true;
-
n+=10;
-
cardService.listFavoriteCards(n,function(result){
-
var cards = result.data.favoriteCards;
-
var starCards = result.data.starCards;
-
-
starCards.sort(function(c1,c2){
-
var c1Name = pinyingUtil.getInitials.convertPinyin(c1.name);
-
var c2Name = pinyingUtil.getInitials.convertPinyin(c2.name);
-
-
return c1Name > c2Name ? 1 : -1;
-
});
-
-
if(starCards && starCards.length> 0) {
-
starCards.forEach(function(c){
-
var compressEntName = dictService.compressEntName(c.companyName);
-
c.compressEntName = compressEntName;
-
});
-
}
-
-
page.setData({
-
"favoriteCards" : cards,
-
"starCards" : starCards,
-
"filterType" : "name",
-
"groups" : cardService.groupCardsByNameFirstLetter(cards),
-
"loadding":false
-
});
-
wx.setStorageSync("setgroups",page.data.groups)
-
});
-
};
-
-
}
-
onLoad: function (options) {
-
-
var geigroups=wx.getStorageSync('setgroups')
-
var result =[]
-
for(var i=0; i<geigroups.length; i+=5){
-
result.push(geigroups.slice(i,i+5));
-
}
-
var resultd=result[0]
-
if(geigroups){
-
page.setData({
-
"groups" : resultd
-
});
-
console.log('緩存')
-
}else{
-
if (wx.getStorageSync("token")) {
-
page.init();
-
page.initProfile();
-
} else {
-
App.addListener("evt_login", function () {
-
page.init();
-
page.initProfile();
-
});
-
}
-
console.log('正常')
-
}
-
}
-
onscrollLower:function(){
-
var page = this;
-
var geigroups=wx.getStorageSync('setgroups') //第一步拿數(shù)據(jù)
-
var result =[] //定義空數(shù)組
-
var n=0; //定義index
-
for(var i=0; i<geigroups.length; i+=10){
-
result.push(geigroups.slice(i,i+10));
-
} //把數(shù)據(jù)每10個(gè)一組push到 result里面
-
n+=1;
-
-
var q=this.data.groups.length;
-
if(geigroups){ //如果有緩存
-
if(geigroups.length<=q) //如果當(dāng)前data的數(shù)據(jù)少于緩存執(zhí)行以下命令
-
if (wx.getStorageSync("token")) { //如果有token請(qǐng)求數(shù)據(jù)
-
page.init();
-
page.initProfile();
-
} else {
-
App.addListener
|