当前位置:   article > 正文

微信小程序开发学习笔记——4.10【小案例】触底加载更多数据onReachBottom_微信小程序触底加载

微信小程序触底加载

>>跟着b站up主“咸虾米_”学习微信小程序开发中,把学习记录存到这方便后续查找。

课程连接:4.10.【小案例】触底加载更多数据onReachBottom_哔哩哔哩_bilibili

一、wx.js中相应部分修改如下代码

  1. Page({
  2. /**
  3. * 页面的初始数据
  4. */
  5. data: {
  6. listArr:[]
  7. },
  8. /**
  9. * 生命周期函数--监听页面加载
  10. */
  11. onLoad(options) {
  12. wx.showLoading({
  13. title: '加载中',
  14. mask:true
  15. })
  16. this.setData({
  17. listArr:[]
  18. })
  19. this.getData();
  20. },
  21. //获取随即猫咪网络请求
  22. getData(){
  23. wx.request({
  24. url: 'https://api.thecatapi.com/v1/images/search?limit=2',
  25. success:res=>{
  26. console.log(res.data);
  27. let oldData=this.data.listArr;
  28. let newData=oldData.concat(res.data) //用concat拼接数据
  29. this.setData({
  30. listArr:newData
  31. })
  32. wx.stopPullDownRefresh() //正常请求完数据之后,就停止显示下拉刷新。
  33. //wx.hideLoading() //正常请求完数据之后,就停止显示加载中
  34. },
  35. complete:err=>{ //无论请求成功还是失败,都停止显示加载中
  36. wx.hideLoading()
  37. wx.hideNavigationBarLoading()
  38. }
  39. })
  40. },
  41. /**
  42. * 页面相关事件处理函数--监听用户下拉动作
  43. */
  44. onPullDownRefresh() {
  45. this.setData({ //先清空,再获取新的数据
  46. listArr:[]
  47. })
  48. this.getData();
  49. },
  50. /**
  51. * 页面上拉触底事件的处理函数
  52. */
  53. onReachBottom() {
  54. wx.showNavigationBarLoading();
  55. this.getData();
  56. },
  57. })

onReachBottom(),触底后执行的函数,导航栏会显示loading,调用getData来加载新数据,而getData()中,用oldData保存旧数组内容,newData保存旧数据加上新读取的10条数据,然后把newData赋值给listArr数组。如此一来,触底后会继续往下加载新的数据,而已加载的数据保持不变。

此时如果下拉刷新,页面只会显示10条,因为在onPullDownRefresh(){}中,一开始就先将数组清空再读取数据了,所以只有10条。

二、其他文件内容和前两篇一样

三、结果

触底几次后,有40组数据

刚下拉刷新时,数组清空

读取数据后,有10组数据

声明:本文内容由网友自发贡献,转载请注明出处:【wpsshop】
推荐阅读
相关标签
  

闽ICP备14008679号