国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

微信小程序上滑加載下拉刷新(onscrollLower)分批加載數據(一)

2019-11-19 16:36:39
字體:
來源:轉載
供稿:網友

微信小程序上滑加載下拉刷新(onscrollLower)分批加載數據(一)

頁面緩存的設置優化了頁面加載,減少了頻繁的調取接口,使用戶在斷網的情況下有更好的體驗。

每個微信小程序都可以有自己的本地緩存,可以通過 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實現微信小程序下拉

因項目需求采用方法二去實現,結合本地儲存是這次的難點,希望對大家有幫助,有不足的地方大家多提建議,共勉。

 相關文章:微信小程序上滑加載下拉刷新(onscrollLower)分批加載數據(二)

感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 酒泉市| 黔东| 天水市| 德惠市| 新余市| 拉萨市| 临泉县| 宜春市| 博湖县| 石渠县| 平和县| 遵义市| 仲巴县| 靖江市| 安图县| 黄浦区| 萝北县| 柏乡县| 沁源县| 临沭县| 顺平县| 九寨沟县| 佛教| 康定县| 玉树县| 郁南县| 神池县| 玉林市| 沽源县| 贵州省| 黎平县| 犍为县| 蕉岭县| 全州县| 松潘县| 东港市| 金沙县| 彰化县| 靖安县| 万荣县| 安远县|