微信小程序上滑加载下拉刷新(onscrollLower)分批加载数据(一)
微信小程序上滑加载下拉刷新(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缓存数据对比,去请求接口。
代码实现
varn=0
page.init=function(callback){
page.data.loading=true;
n+=10;
cardService.listFavoriteCards(n,function(result){
varcards=result.data.favoriteCards;
varstarCards=result.data.starCards;
starCards.sort(function(c1,c2){
varc1Name=pinyingUtil.getInitials.convertPinyin(c1.name);
varc2Name=pinyingUtil.getInitials.convertPinyin(c2.name);
returnc1Name>c2Name?1:-1;
});
if(starCards&&starCards.length>0){
starCards.forEach(function(c){
varcompressEntName=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){
vargeigroups=wx.getStorageSync('setgroups')
varresult=[]
for(vari=0;i
onscrollLower:function(){
varpage=this;
vargeigroups=wx.getStorageSync('setgroups')//第一步拿数据
varresult=[]//定义空数组
varn=0;//定义index
for(vari=0;i
总结
加载数据的几种方法:
方法一:onPullDownRefresh和onReachBottom方法实现小程序下拉加载和上拉刷新
方法二:在scroll-view里设定bindscrolltoupper和bindscrolltolower实现微信小程序下拉
因项目需求采用方法二去实现,结合本地储存是这次的难点,希望对大家有帮助,有不足的地方大家多提建议,共勉。
相关文章:微信小程序上滑加载下拉刷新(onscrollLower)分批加载数据(二)
感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!