小程序API —— 55页面处理函数 -上拉加载

上拉加载是小程序中常见的一种加载方式,当用户滑动页面到底部时,会自动加载更多的内容,以便用户继续浏览;

小程序中实现上拉加载的方式:

  1. 在 app.json 或者 page.json 中配置距离页面底部的距离:onReachBottonDistance;默认取 50px;
  2. 在页面.js 中定义· onReachBottom 事件监听用户上拉加载;

下面我们使用微信开发者工具来演示一下上拉加载功能:

  • 在 pages/cate/cate.json 文件中配置 onReachBottonDistance 参数值,这里设置为 100px,表示具体底部为 100px 时触发上拉加载函数,如下:

    yaml 复制代码
    {
      "usingComponents": {},
      "onReachBottomDistance": 100
    }
  • 在 pages/cate/cate.scss 文件中配置页面高度为 1000 px,用于显示上拉效果,如下:

    css 复制代码
    page {
      height: 1000px;
    }
  • 在 pages/cate/cate.js 文件中定义 onReachBottom 事件监听用户上拉加载,如下:

    javascript 复制代码
    Page({
      // 监听用户上拉加载
      onReachBottom(){
        console.log("监听用户上拉加载");
      }
    })
  • 点击编辑,可以看到页面右侧有一个滚动条,上拉页面,当距离 page 底部还有 100px 的时候,触发 js 文件中定义的 onReachBottom 事件,可以看到在 Console 中输出了 console 打印的信息,如下:

接着使用微信开发者工具实现一个需求:当页面上拉加载时,页面当前显示的数字不断变大;

  • 在 pages/cate/cate.wxml 中添加初始页面布局,如下:

    html 复制代码
    <view wx:for="{{ numList }}" wx:key="*this" class="{{ ((index + 1) % 2 === 0) ? 'even' : 'odd' }}">
      {{ item }}
    </view>
  • 在 pages/cate/cate.scss中添加样式调整,设置 view 的高度,使用 flex 流式布局,同时对奇数和偶数设置不同的背景颜色,如下:

    css 复制代码
    view {
      height: 400rpx;
      display: flex;
      align-items: center;
      justify-content: center;
    }
    
    .odd {
      background-color: lightskyblue;
    }
    
    .even {
      background-color: lightsalmon;
    }
  • 在 pages/cate/cate.js 中实现具体的逻辑,当滑动到页面底部时,给 numList 数据增加新值,使其不断变大,如下:

    javascript 复制代码
    Page({
    
      data: {
        numList: [1, 2, 3]
      },
    
      // 监听用户上拉加载
      onReachBottom(){
        
        wx.showLoading({
          title: '数据加载中',
        })
    
        // 当上拉时,需要数字进行累加
        // 使用 setTimeout 模拟服务器请求(需要等待数据发送接收)
        setTimeout(()=>{
          // 获取数组最后一项
          const lastNum = this.data.numList[this.data.numList.length - 1];
          // 定义需要追加的元素
          const newArr = [lastNum + 1, lastNum + 2, lastNum + 3];
    
          // 更新数据
          this.setData({
            numList: [...this.data.numList, ...newArr]
          })
          wx.hideLoading()
        }, 1500)
      }
    })
  • 点击编译,上拉页面,可以看到当前页面的数值不断变大,如下所示:

    参考视频:尚硅谷微信小程序开发教程

相关推荐
2501_915106327 小时前
如何查看手机使用记录:Android和iOS设备全面指南
android·ios·智能手机·小程序·uni-app·iphone·webview
chaffererdog11 小时前
uniapp开发微信小程序使用vk-uview-ui的uSearch搜索组件,在微信开发者工具中点击输入框会意外触发custom事件
微信小程序·小程序·uni-app
2501_9159184117 小时前
Flutter 加固方案全解析,从 Dart 层到 IPA 成品的多工具协同防护体系
flutter·macos·ios·小程序·uni-app·cocoa·iphone
我命由我1234518 小时前
微信小程序 - 内容弹出框实现(Vant Weapp 实现、原生实现)
开发语言·前端·javascript·微信小程序·小程序·前端框架·js
小码哥06818 小时前
陪诊小程序核心功能拆解:预约、导航与提醒
小程序·项目源码·预约系统·陪诊·陪诊系统开发
q_191328469519 小时前
基于Springboot+uniapp的智慧停车场收费小程序
java·vue.js·spring boot·小程序·uni-app·毕业设计·计算机毕业设计
2501_9160074719 小时前
深入理解 iOS 文件管理体系,从沙盒结构到多工具协同的工程化文件管理实践
android·ios·小程序·https·uni-app·iphone·webview
00后程序员张19 小时前
iOS 性能检测工具深度解析 多工具协同下的全维度性能检测体系建设
android·ios·小程序·https·uni-app·iphone·webview
说私域19 小时前
天猫卖家运营突围:基于开源AI智能名片链动2+1模式S2B2C商城小程序的转型路径研究
人工智能·小程序·开源
00后程序员张20 小时前
Fiddler调试工具全面解析 HTTPHTTPS抓包、代理设置与接口测试实战教程
前端·测试工具·ios·小程序·fiddler·uni-app·webview