全国服务热线:4008-888-888

行业新闻

小程序流程是多少钱_微信小程序上滑加载下拉改

微信小程序上滑加载下拉刷新(onscrollLower)分批加载数据(一)     投稿:lqh   这篇文章主要介绍了微信小程序上滑加载下拉刷新(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){
 pressEntName = panyName);
 c.compressEntName = compressEntName;
 page.setData({
 "favoriteCards" : cards,
 "starCards" : starCards,
 "filterType" : "name",
 "grou凡科抠图" : cardService.groupCardsByNameFirstLetter(cards),
 "loadding":false
 wx.setStorageSync("setgrou凡科抠图",page.data.grou凡科抠图)

var geigrou凡科抠图=wx.getStorageSync('setgrou凡科抠图') //第一步拿数据 var result =[] //定义空数组 var n=0; //定义index for(var i=0; i geigrou凡科抠图.length; i+=10){ result.push(geigrou凡科抠图.slice(i,i+10)); } //把数据每10个一组push到 result里面 n+=1; var q=this.data.grou凡科抠图.length; if(geigrou凡科抠图){ //如果有缓存 if(geigrou凡科抠图.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({ "grou凡科抠图" : result[n], });

总结

加载数据的几种方法:

方法一:onPullDownRefresh和onReachBottom方法实现小程序下拉加载和上拉刷新

方法二:在scroll-view里设定bindscrolltoupper和bindscrolltolower实现微信小程序下拉

因项目需求采用方法二去实现,结合本地储存是这次的难点,希望对大家有帮助,有不足的地方大家多提建议,共勉。

 



在线客服

关闭

客户服务热线
4008-888-888


点击这里给我发消息 在线客服

点击这里给我发消息 在线客服