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

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

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

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

javascript 复制代码
Page({

  /**
   * 页面的初始数据
   */
  data: {
    listArr:[]
  },

  /**
   * 生命周期函数--监听页面加载
   */
  onLoad(options) {
    wx.showLoading({
      title: '加载中',
      mask:true
    })
    this.setData({
      listArr:[]
    })
    this.getData();
  },
  //获取随即猫咪网络请求
  getData(){
    wx.request({
      url: 'https://api.thecatapi.com/v1/images/search?limit=2',
      success:res=>{
        console.log(res.data);
        let oldData=this.data.listArr;
        let newData=oldData.concat(res.data) //用concat拼接数据
        this.setData({
          listArr:newData
        })
        wx.stopPullDownRefresh()  //正常请求完数据之后,就停止显示下拉刷新。
        //wx.hideLoading()  //正常请求完数据之后,就停止显示加载中
      },
      complete:err=>{  //无论请求成功还是失败,都停止显示加载中
        wx.hideLoading() 
        wx.hideNavigationBarLoading()
      }
    })
  },


  /**
   * 页面相关事件处理函数--监听用户下拉动作
   */
  onPullDownRefresh() {
    this.setData({ //先清空,再获取新的数据
      listArr:[]
    })
    this.getData();
  },

  /**
   * 页面上拉触底事件的处理函数
   */
  onReachBottom() {
    wx.showNavigationBarLoading();
    this.getData();
  },


})

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

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

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

三、结果

触底几次后,有40组数据

刚下拉刷新时,数组清空

读取数据后,有10组数据

相关推荐
JJJJ_iii8 分钟前
【深度学习03】神经网络基本骨架、卷积、池化、非线性激活、线性层、搭建网络
网络·人工智能·pytorch·笔记·python·深度学习·神经网络
sensen_kiss11 分钟前
INT301 Bio-computation 生物计算(神经网络)Pt.1 导论与Hebb学习规则
人工智能·神经网络·学习
玉石观沧海14 分钟前
高压变频器故障代码解析F67 F68
运维·经验分享·笔记·分布式·深度学习
koko4227 分钟前
天津小公司面经
java·学习·面试
初级炼丹师(爱说实话版)1 小时前
MySql速成笔记5(多表关系)
笔记
Stanford_11062 小时前
关于嵌入式硬件需要了解的基础知识
开发语言·c++·嵌入式硬件·微信小程序·微信公众平台·twitter·微信开放平台
明月(Alioo)2 小时前
用AI帮忙,开发刷题小程序:软考真经微信小程序API接口文档(更新版)
微信小程序·小程序
七夜星七夜月2 小时前
生成与无监督学习 —— 奶茶店的 “新品研发与原料优化体系”
学习
iconball2 小时前
个人用云计算学习笔记 --19 (MariaDB服务器)
linux·运维·笔记·学习·云计算
岑梓铭2 小时前
《考研408数据结构》第四章(串和串的算法)复习笔记
数据结构·笔记·考研·算法