微信小程序上滑加载下拉刷新(onscrollLower)分批加载数据(一)

发布时间 - 2026-01-11 01:04:55    点击率:

微信小程序上滑加载下拉刷新(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)分批加载数据(二)

感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!


# 微信小程序上滑加载下拉刷新  # 微信小程序分批加载数据  # 小程序Scroll-view上拉滚动刷新数据  # 微信小程序常用功能实例汇总包括上拉刷新  # 下拉加载  # 列表数据绑定  # 轮播  # 参数传递  # 微信小程序云开发实现分页刷新获取数据  # 关于微信小程序使用echarts/数据刷新重新渲染/图层遮挡问题  # 微信小程序上滑加载下拉刷新(onscrollLower)分批加载数据(二)  # 微信小程序返回上一页刷新组件数据的示例代码  # 加载  # 自己的  # 鼠标  # 相关文章  # 可以通过  # 希望能  # 分页  # 自定义  # 自带  # 谢谢大家  # 装了  # 用户登陆  # 值为  # 多提  # 几种方法  # 情况下  # 断网  # 文档  # 减少了  # init 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: Laravel PHP版本要求一览_Laravel各版本环境要求对照  香港服务器部署网站为何提示未备案?  Linux系统运维自动化项目教程_Ansible批量管理实战  详解Huffman编码算法之Java实现  如何构建满足综合性能需求的优质建站方案?  软银砸40亿美元收购DigitalBridge 强化AI资料中心布局  Android利用动画实现背景逐渐变暗  Laravel怎么发送邮件_Laravel Mail类SMTP配置教程  ,在苏州找工作,上哪个网站比较好?  Laravel如何配置.env文件管理环境变量_Laravel环境变量使用与安全管理  PHP怎么接收前端传的文件路径_处理文件路径参数接收方法【汇总】  C语言设计一个闪闪的圣诞树  网站广告牌制作方法,街上的广告牌,横幅,用PS还是其他软件做的?  高性价比服务器租赁——企业级配置与24小时运维服务  Laravel队列任务超时怎么办_Laravel Queue Timeout设置详解  如何在万网自助建站平台快速创建网站?  Chrome浏览器标签页分组怎么用_谷歌浏览器整理标签页技巧【效率】  如何用狗爹虚拟主机快速搭建网站?  百度浏览器ai对话怎么关 百度浏览器ai聊天窗口隐藏  高防网站服务器:DDoS防御与BGP线路的AI智能防护方案  如何使用 Go 正则表达式精准提取括号内首个纯字母标识符(忽略数字与嵌套)  JavaScript如何操作视频_媒体API怎么控制播放  海南网站制作公司有哪些,海口网是哪家的?  油猴 教程,油猴搜脚本为什么会网页无法显示?  Internet Explorer官网直接进入 IE浏览器在线体验版网址  Laravel如何为API编写文档_Laravel API文档生成与维护方法  Win11怎么关闭透明效果_Windows11辅助功能视觉效果设置  如何注册花生壳免费域名并搭建个人网站?  Swift开发中switch语句值绑定模式  HTML5打空格有哪些误区_新手常犯的空格使用错误【技巧】  如何用JavaScript实现文本编辑器_光标和选区怎么处理  网易LOFTER官网链接 老福特网页版登录地址  ChatGPT怎么生成Excel公式_ChatGPT公式生成方法【指南】  Laravel如何实现本地化和多语言支持_Laravel多语言配置与翻译文件管理  Laravel如何集成Inertia.js与Vue/React?(安装配置)  Laravel如何使用Livewire构建动态组件?(入门代码)  JavaScript如何实现继承_有哪些常用方法  教学论文网站制作软件有哪些,写论文用什么软件 ?  Laravel如何获取当前用户信息_Laravel Auth门面获取用户ID  Laravel如何实现API速率限制?(Rate Limiting教程)  怎么制作一个起泡网,水泡粪全漏粪育肥舍冬季氨气超过25ppm,可以有哪些措施降低舍内氨气水平?  微信小程序 HTTPS报错整理常见问题及解决方案  Laravel如何生成和使用数据填充?(Seeder和Factory示例)  如何快速生成ASP一键建站模板并优化安全性?  如何在服务器上配置二级域名建站?  Laravel如何使用Service Provider注册服务_Laravel服务提供者配置与加载  如何自定义建站之星模板颜色并下载新样式?  如何在 Pandas 中基于一列条件计算另一列的分组均值  Linux系统命令中screen命令详解  如何选择可靠的免备案建站服务器?