多平台统一管理软件接口,如何实现多平台统一管理软件接口
317
2023-05-16
微信小程序上滑加载下拉刷新(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缓存数据对比,去请求接口。
代码实现
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 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 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)分批加载数据(二) 感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!WDKmJUkHx
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 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)分批加载数据(二) 感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!WDKmJUkHx
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)分批加载数据(二)
感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!WDKmJUkHx
版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。
发表评论
暂时没有评论,来抢沙发吧~