uni-app上拉加载更多⑩

文章目录

十六、文章列表制作-上拉加载更多

一、使用 uni-load-more 插件

下载地址:https://ext.dcloud.net.cn/plugin?id=29

使用:

react 复制代码
<uni-load-more status="loading"></uni-load-more>
二、修改参数传递
  1. 前端添加 page 及 size 属性到云函数

  2. 云函数内进行返回值限制处理

    javascript 复制代码
    const list = await db
      .collection("article")
      .aggregate() // 使用聚合的形式进行数据的获取
      .match(matchObj) // 根据匹配条件进行数据返回
      .project({
        content: 0, // 本次查询不需要返回文章详情给前端
      })
      .skip(pageSize * (page - 1)) // 首页从0开始计算
      .limit(pageSize) // 每页最多返回多少条数据
      .end();
  3. 监听 scroll-view 的 scrolltolower 事件,触底时进行新的数据请求,当前的 page 值

  4. 前端调整数据处理将直接赋值变为追加数据

    javascript 复制代码
    // 填充数据时改变为追加数据
    let oldList = this.articleData[currentIndex] || [];
    oldList.push(...articleList);
    this.$set(this.articleData, currentIndex, oldList);
三、分类页数处理
  1. 创建每一个分类的存储对象,含 page 及加载状态

    javascript 复制代码
    loadData:{
    	page:1,
    	loading:loading
    }
  2. 处理数据全部加载完成状态

    react 复制代码
    // 判断当前后端没有返回数据处理
          if(!articleList.length) {
            this.loadData[currentIndex] = {
              loading:"noMore",
              page:this.loadData[currentIndex].page
            }
            this.$forceUpdate()
            return
          }
相关推荐
乌托邦1 天前
uni-mini-ci:让 uniapp 小程序构建后自动预览和上传
前端·vue.js·uni-app
敲代码的鱼1 天前
NFC读卡能力 支持安卓/iOS/鸿蒙 UTS插件
android·ios·uni-app
西洼工作室1 天前
UniApp云开发笔记
前端·笔记·uni-app
Martin -Tang1 天前
uniapp 实现录音操作,长按录音,放开取消
前端·javascript·vue.js·uni-app·css3·录音
西洼工作室2 天前
UniApp开发全攻略:从生命周期到路由传值
前端·javascript·uni-app
Martin -Tang3 天前
uniapp+vue3+ts自定义表格
javascript·vue.js·uni-app
LinMin_Rik3 天前
解决win11专业版HbuilderX编译vue3的uniappX失败问题
uni-app
游戏开发爱好者83 天前
iOS应用性能监控:Pre-Main与Main函数耗时分析及Time Profiler使用教程
android·ios·小程序·https·uni-app·iphone·webview
西洼工作室4 天前
个人开发者接入阿里云号码认证服务AliCloud-NirvanaPns实现一键登录
python·阿里云·uni-app·全栈·认证授权
2501_916008894 天前
ChatGPT前端开发学习指南:Visual Studio Code与谷歌浏览器安装配置详解
ide·vscode·ios·小程序·uni-app·编辑器·iphone