微信小程序上滑加载下拉刷新(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缓存数据对比,去请求接口。 代码实现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) { page.setData({ } 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('正常') } } 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{ 总结加载数据的几种方法: 方法一:onPullDownRefresh和onReachBottom方法实现小程序下拉加载和上拉刷新方法二:在scroll-view里设定bindscrolltoupper和bindscrolltolower实现微信小程序下拉因项目需求采用方法二去实现,结合本地储存是这次的难点,希望对大家有帮助,有不足的地方大家多提建议,共勉。 相关文章: 感谢阅读,希望能帮助到大家,谢谢大家对本站的支持! (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |