這篇文章給大家分享的是有關微信小程序如何實現上滑加載下拉刷新的內容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。

頁面緩存的設置優化了頁面加載,減少了頻繁的調取接口,使用戶在斷網的情況下有更好的體驗。
每個微信小程序都可以有自己的本地緩存,可以通過 wx.setStorage(wx.setStorageSync)、wx.getStorage(wx.getStorageSync)、wx.clearStorage(wx.clearStorageSync)可以對本地緩存進行設置、獲取和清理。本地緩存大為10MB。
注意: localStorage 是永久存儲的,但是我們不建議將關鍵信息全部存在 localStorage,以防用戶換設備的情況。
項目需求
通過使用scroll-view 自定義的鼠標滾動事件onscrollLower,監聽頁面下拉事件
page.init()的方法里封裝了請求數據的接口,后臺api文檔自帶分頁pageSize,默認值為10,-1為請求全部數據。
說明:
觸發下滑事件通過與頁面data緩存數據對比,去請求接口。
代碼實現
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') //第一步拿數據
var result =[] //定義空數組
var n=0; //定義index
for(var i=0; i<geigroups.length; i+=10){
result.push(geigroups.slice(i,i+10));
} //把數據每10個一組push到 result里面
n+=1;
var q=this.data.groups.length;
if(geigroups){ //如果有緩存
if(geigroups.length<=q) //如果當前data的數據少于緩存執行以下命令
if (wx.getStorageSync("token")) { //如果有token請求數據
page.init();
page.initProfile();
} else {
App.addListener("evt_login", function () { //監聽用戶登陸以后 請求數據
page.init();
page.initProfile();
});
}
}else{
page.setData({
"groups" : result[n],
});
}
},總結
加載數據的幾種方法:
方法一:onPullDownRefresh和onReachBottom方法實現小程序下拉加載和上拉刷新
方法二:在scroll-view里設定bindscrolltoupper和bindscrolltolower實現微信小程序下拉
感謝各位的閱讀!關于“微信小程序如何實現上滑加載下拉刷新”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!
另外有需要云服務器可以了解下創新互聯建站m.kartarina.com,海內外云服務器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務器、裸金屬服務器、高防服務器、香港服務器、美國服務器、虛擬主機、免備案服務器”等云主機租用服務以及企業上云的綜合解決方案,具有“安全穩定、簡單易用、服務可用性高、性價比高”等特點與優勢,專為企業上云打造定制,能夠滿足用戶豐富、多元化的應用場景需求。
當前名稱:微信小程序如何實現上滑加載下拉刷新-創新互聯
文章位置:http://m.kartarina.com/article42/dhjihc.html
成都網站建設公司_創新互聯,為您提供網站建設、企業網站制作、標簽優化、響應式網站、網站內鏈、外貿建站
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯