小程序滚动加载分页处理(新详细教程)

简介: 成品展示:下滑可以获取刷新后的新数据结合旧数据渲染前端,从而实现分页功能关注、收藏、点赞3连😀!!!关注、收藏、点赞3连😀!!!# 一、所使用到方法及后端函数的介绍1.小程序涉及到的方法介绍看下微信文档说明:监听用户滑到底部操作:onReachBottom:funtion(){}思路:在里面写数据调用,对每次滑到底部进行分页起始和分页结束变量累加即可第二个就是concat用法:将旧数据与新数据拼接1.TP5后端查询方法limit(起始页,终止页)二、完整代

成品展示:

在这里插入图片描述
下滑可以获取刷新后的新数据结合旧数据渲染前端,从而实现分页功能

关注、收藏、点赞3连😀!!!
关注、收藏、点赞3连😀!!!


# 一、所使用到方法及后端函数的介绍 ## 1.小程序涉及到的方法介绍 看下微信文档说明: ![在这里插入图片描述](https://ucc.alicdn.com/images/user-upload-01/5ee34529eba94b2fa7eac0a38839606e.png) 监听用户滑到底部操作: > onReachBottom:funtion(){ > > } 思路:在里面写数据调用,对每次滑到底部进行分页起始和分页结束变量累加即可 第二个就是 > concat 用法:将旧数据与新数据拼接 ## 1.TP5后端查询方法 > limit(起始页,终止页)
# 二、完整代码 首先在目标js文件:(多看注释) data中添加初始化数据, ```javascript data: { start_page:0,//开始页面 pagenum: 2, //初始页默认值 new_list:[],//必须初始化 不然报错 } ``` 这里插一嘴,这三个参数必须先初始化,否则会出现两个问题,第一个就是页面不能进行累加,第二个就是在拼接数据的时候如果没有初始数据new_list,就会unfinded,我**在这里踩坑了,这里做一下记录!!!** ```javascript onReachBottom: function() { // Do something when page reach bottom. var that=this; console.log("触发底部"); wx.showLoading({ title: '刷新中..', }) var start_page = that.data.start_page + that.data.pagenum; // //从最初的0 +需要显示的条数 var pagenum = that.data.pagenum + 2; //获取当前页数并+上希望显示的条数 console.log(pagenum); that.setData({ pagenum: pagenum, //更新当前页数 start_page:start_page }) //更新起始页和初始页 //调用你的方法 我这里仅做一个测试,这里改一下,不做过多说明 that.get_new_second_list(wx.getStorageSync('school_code_cloud').school_code); //获取该学校最新二手列表 分页 }, ``` 调用后来到该方法: ```javascript get_new_second_list:function(){ let that=this; //获取上次加载的旧数据,第一次为空 var oldlists = that.data.new_list; // console.log(oldlists); wx.request({ url: '', //仅为示例,并非真实的接口地址 data: { start_page:that.data.start_page, //开始 pagesize: that.data.pagenum, //每页显示条数 }, header: { 'content-type': 'application/json' // 默认值 }, success (res) { wx.hideLoading({ success: (res) => {}, }) //将旧数据与新数据合并 var newlists = oldlists.concat(res.data) //合并数据 res.data 你的数组数据 console.log(res.data) if (res.data=='') { wx.showToast({ title: '没有了!!', icon:'none' }) //console.log("没有了"); } //渲染前端即可 that.setData({ new_list:newlists }) } }) }, ``` 这里还需要说一下,进到当前页面先刷新默认数据, 需要用到onload()方法进行调用get_new_second_list() ```php onLoad: function (options) { that.get_new_second_list(); } ``` 这里调用后使用刚刚在data中初始化的值,也就是显示两个,如果需要默认显示多个,请自己调整! **后端接口:自己改改就可以,不要连改动都不会,有的参数是我的** ```php public function Get_new_second_list(){ //分页处理 $param1=input("school_code"); $start_page=input("start_page"); $pagesize=input("pagesize"); if ($param1) { $resu=DB::table('seconlist')->where(["school_code"=>$param1,"is_sale"=>'1'])->order("put_time desc")->limit($start_page,$pagesize)->select(); return json($resu); } else { // code... } } ```
# 总结 ** 先用微信给的API对滑动到底部进行监控,监控到数据就进行页面数量的增加并写入data中,再调用你获取数据的方法进行业务处理,对返回的新数据进行与原数据的拼接,再次渲染wxml,至于样式这里就不给出了,方法通用就行!!** 关注、收藏、点赞3连😀!!! 关注、收藏、点赞3连😀!!! 关注、收藏、点赞3连😀!!! 关注、收藏、点赞3连😀!!!
相关文章
|
3月前
|
XML 小程序 前端开发
小程序制作教程
小程序制作教程
101 3
小程序制作教程
|
6月前
|
小程序
【微信小程序-原生开发】实用教程12 - 注册页(含获取用户微信昵称,原生form的表单提交,t-result 的使用)
【微信小程序-原生开发】实用教程12 - 注册页(含获取用户微信昵称,原生form的表单提交,t-result 的使用)
62 0
|
6月前
|
小程序 数据库
【微信小程序-原生开发】实用教程10 - 动态的新增、修改、删除(含微信云数据库的新增、修改、删除,表单弹窗、确认弹窗、日期选择器、单行输入框、多行输入框、滑动组件的使用)
【微信小程序-原生开发】实用教程10 - 动态的新增、修改、删除(含微信云数据库的新增、修改、删除,表单弹窗、确认弹窗、日期选择器、单行输入框、多行输入框、滑动组件的使用)
232 0
|
6月前
|
小程序 API 数据库
【微信小程序-原生开发】实用教程09 - 可滚动选项,动态列表-步骤条(含事件传参),动态详情(含微信云查询单条数据 doc)
【微信小程序-原生开发】实用教程09 - 可滚动选项,动态列表-步骤条(含事件传参),动态详情(含微信云查询单条数据 doc)
101 0
|
3月前
|
缓存 小程序 UED
如何利用小程序的生命周期函数实现数据的加载和更新?
如何利用小程序的生命周期函数实现数据的加载和更新?
117 4
|
5月前
|
监控 小程序 数据处理
揭秘支付宝小程序性能优化秘籍:从加载到运行,每一步都快人一步!
【8月更文挑战第27天】本文深入探讨了支付宝小程序性能优化的关键技术和策略,包括减少网络请求、利用CDN加速、代码按需加载、图片压缩、懒加载以及性能监控等多方面内容,并提供了实用的示例代码,帮助开发者显著提升小程序的加载速度与运行效率,创造更佳用户体验。
113 1
|
6月前
|
小程序 PHP
全新UI自助图文打印系统小程序源码 PHP后端 附教程
全新UI自助图文打印系统小程序源码 PHP后端 附教程
304 2
|
6月前
|
前端开发 小程序
【微信小程序-原生开发】实用教程20 - 生成海报(实战范例为生成活动海报,内含生成指定页面的小程序二维码,保存图片到手机,canvas 系列教程)
【微信小程序-原生开发】实用教程20 - 生成海报(实战范例为生成活动海报,内含生成指定页面的小程序二维码,保存图片到手机,canvas 系列教程)
440 0
|
6月前
|
小程序
【微信小程序-原生开发】富文本编辑器 editor 的使用教程
【微信小程序-原生开发】富文本编辑器 editor 的使用教程
727 0
【微信小程序-原生开发】富文本编辑器 editor 的使用教程
|
6月前
|
小程序 前端开发
【微信小程序-原生开发】实用教程22 - 绘制图表(引入 echarts,含图表的懒加载-获取到数据后再渲染图表,多图表加载等技巧)
【微信小程序-原生开发】实用教程22 - 绘制图表(引入 echarts,含图表的懒加载-获取到数据后再渲染图表,多图表加载等技巧)
344 0