微信小程序下拉刷新获取数据和触底事件刷新实现

一、下拉刷新

1.json文件

说明:开启下拉刷新,然后设置窗口的背景色,方便观看。

  "enablePullDownRefresh": true,"backgroundColor":"#FFC0CB"

 

2. js文件

说明:重新发起请求,并显示加载中

   * 页面相关事件处理函数--监听用户下拉动作*/onPullDownRefresh() {this.getData()wx.showLoading({title: '加载中',})},

 

 3.js文件

说明:当数据请求成功后,收回下拉刷新框并关闭加载中。

      success: ({data}) => {// 数据加载成功,关闭下拉刷新wx.stopPullDownRefresh()// 成功后并关闭加载中wx.hideLoading()this.setData({arrList:data.data})},

二、触底事件刷新

2.json文件

说明:onReachBottomDistance定义了从页面底部的距离为50px,当滚动距离接近到这个值时,通常会触发一个函数或事件来加载更多内容。

  "onReachBottomDistance": 50

 说明:当距离页面底部为50px的时候,重新发起数据请求,并添加一个显示导航条加载动画(转态遮罩)

   * 页面上拉触底事件的处理函数*/onReachBottom() {this.getData()//  在当前页面显示导航条加载动画,是一个状态遮罩wx.showNavigationBarLoading()},

 说明:改造了getData()函数,将以前的数据和现在获取的数据进行相加。以此下拉获取更多的信息。

  getData() {wx.request({url: '**',method:"GET",success: ({data:res}) => {// 数据加载成功,关闭下拉刷新wx.stopPullDownRefresh()// 成功后并关闭加载中wx.hideLoading()wx.hideNavigationBarLoading()let oldData=this.data.arrListlet newData=oldData.concat(res.data)this.setData({arrList:newData})}})},

三、源码

3.1 xml文件

<!-- 简单的前台页面 -->
<view>
<block wx:for="{{arrList}}" wx:key="id">
<view>猫儿</view>
<image src="{{item.url}}" mode=""/>
</block>
</view>

3.2 js文件

// pages/refresh/refresh.js
Page({/*** 页面的初始数据*/data: {arrList:[]},getData() {wx.request({url: '**',method:"GET",success: ({data:res}) => {// 数据加载成功,关闭下拉刷新wx.stopPullDownRefresh()// 成功后并关闭加载中wx.hideLoading()//关闭导航加载wx.hideNavigationBarLoading()let oldData=this.data.arrListlet newData=oldData.concat(res.data)this.setData({arrList:newData})}})},/*** 生命周期函数--监听页面加载*/onLoad(options) {this.getData()wx.showLoading({title: '加载中',})},/*** 生命周期函数--监听页面初次渲染完成*/onReady() {},/*** 生命周期函数--监听页面显示*/onShow() {},/*** 生命周期函数--监听页面隐藏*/onHide() {},/*** 生命周期函数--监听页面卸载*/onUnload() {},/*** 页面相关事件处理函数--监听用户下拉动作*/onPullDownRefresh() {this.getData()//清空数据,重新获取数据(归零)this.setData({arrList:[]})},/*** 页面上拉触底事件的处理函数*/onReachBottom() {this.getData()//  在当前页面显示导航条加载动画,是一个状态遮罩wx.showNavigationBarLoading()},/*** 用户点击右上角分享*/onShareAppMessage() {}
})

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/4213.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

主数据建模和维护流程

主数据建模的工作流程 开发人员实现主数据建模的工作流程一般包括以下步骤&#xff1a; 确定需求&#xff1a;与业务部门或客户进行沟通&#xff0c;明确主数据建模的需求和目标。 收集数据&#xff1a;收集相关的数据源&#xff0c;如数据库、文件等&#xff0c;并对数据进行…

【问题总结】Docker环境下备份和恢复postgresql数据库

目录 文章目录 以从备份恢复forest_resources库为例一、备份数据库二、需要还原的数据库准备1 删除掉远程的库。2 重新创建一个空的库。可以使用sql3 找到数据库存放的路径&#xff0c;并将备份文件上传到对应的路径下 三、 进入docker容器内部&#xff0c;执行数据库恢复附录…

Vue3统计数值(Statistic)

可自定义设置以下属性&#xff1a; 数值的标题&#xff08;title&#xff09;&#xff0c;类型&#xff1a;string | slot&#xff0c;默认&#xff1a;‘’数值的内容&#xff08;value&#xff09;&#xff0c;类型&#xff1a;string | number&#xff0c;默认&#xff1a;…

AlphaPose复现配置教程

AlphaPose复现配置教程 AlphaPose介绍 AlphaPose是一种准确的多人姿态估计器&#xff0c;这是第一个在COCO数据集上达到70 mAP (75 mAP)和在MPII数据集上达到80 mAP (82.1 mAP)的开源系统。为了匹配跨帧的同一人的姿态&#xff0c;我们还提供了一种高效的在线姿态跟踪器&…

scala学习手册

1. case class学习 样例类模式匹配 1.1 样例类&#xff08;case class&#xff09;适合用于不可变的数据。它是一种特殊的类&#xff0c;能够被优化以用于模式匹配。 case class MetaData(userId: String)case class Book(name: String) {def printBookName(): Unit {printl…

跨网络的通信过程、路由的作用以及默认网关

如下网络拓扑图&#xff0c;交换机0所在的网段为192.168.1.0/24&#xff0c;交换机1所在网段为192.168.2.0/24&#xff0c;且各自有2台主机&#xff1a; 假设PC0&#xff08;192.168.1.10/32&#xff09;要跟PC4&#xff08;192.168.2.11/32&#xff09;通信&#xff0c;如何实…

iptables 命令

清除规则 iptables -D INPUT 2 iptables -D OUTPUT 2 默认规则 iptables -P INPUT DROP iptables -P INPUT ACCEPT iptables -P OUTPUT DROP iptables -P OUTPUT ACCEPT 添加规则 iptables -A INPUT -s 192.168.80.11 -j ACCEPT iptables -A INPUT -s 192.168.80.11 -j D…

k8s 对外服务之 Ingress

//Ingress 简介 service的作用体现在两个方面&#xff0c;对集群内部&#xff0c;它不断跟踪pod的变化&#xff0c;更新endpoint中对应pod的对象&#xff0c;提供了ip不断变化的pod的服务发现机制&#xff1b;对集群外部&#xff0c;他类似负载均衡器&#xff0c;可以在集群内外…

函数和控制流

专栏简介&#xff1a;本专栏作为Rust语言的入门级的文章&#xff0c;目的是为了分享关于Rust语言的编程技巧和知识。对于Rust语言&#xff0c;虽然历史没有C、和python历史悠远&#xff0c;但是它的优点可以说是非常的多&#xff0c;既继承了C运行速度&#xff0c;还拥有了Java…

7.运算符优先级

优先级运算符顺序1小括号 &#xff08;&#xff09; 2一元运算符 -- &#xff01; 3算数运算符先* / %后 -4关系运算符> > < <5相等运算符 &#xff01; &#xff01;6逻辑运算符先&&后||7赋值运算符8逗号运算符&#xff0c; 一…

Simulink仿真模块 - Data Store Read

Data Store Read:从数据存储中读取数据 在仿真库中的位置为:Simulink / Signal Routing 模型为: 说明 Data Store Read 模块将指定数据存储中的数据复制到其输出中。多个 Data Store Read 模块可从同一个数据存储读取数据。 用来读取数据的源数据存储由 Data Store Memory 模…

Ceph的部署与应用

文章目录 Ceph的部署与应用一.存储基础1.单机存储设备(1)DAS&#xff08;直接附加存储&#xff0c;是直接接到计算机的主板总线上去的存储&#xff09;(2)NAS&#xff08;网络附加存储&#xff0c;是通过网络附加到当前主机文件系统之上的存储&#xff09;(3)SAN&#xff08;存…

vue+element-ui通用后台管理系统(适合新手)

vueelement-ui通用后台管理系统&#xff08;适合新手&#xff09; 1、使用到的技术 使用vue2element-uiaxiosjs-cookielessecharts实现的一个简易的通用后台管理系统&#xff0c;具有很强的可扩展性&#xff0c;修改简单&#xff0c;只要有点前端基础就能看懂&#xff1b; 2…

怎么学习Java数据库连接(JDBC)? - 易智编译EaseEditing

学习Java数据库连接&#xff08;JDBC&#xff09;是掌握Java与数据库交互的关键步骤。以下是学习Java JDBC的一些建议&#xff1a; 先掌握Java基础&#xff1a; 在学习JDBC之前&#xff0c;确保你已经掌握了Java的基本语法、面向对象编程和其他核心概念。这将有助于更好地理解…

webpack学习

1.webpack 项目-----》装载器------》插件------》浏览器 loader&#xff1a;将浏览器不能识别的文件转化为html&#xff0c;js&#xff0c;css 插件&#xff1a;对文件进行处理像压缩&#xff0c;合并等 入口&#xff1a; 出口&#xff1a; 创建webpack webpack init -y webp…

Spring、SpringBoot、SpringCloud、SpringCloud Alibaba、Elasticsearch版本对应,附下载地址

1、GitHub Alibaba 发布SpringCloud Alibaba和SpringCloud 、SpringBoot版本 Spring Cloud Alibaba VersionSpring Cloud VersionSpring Boot2022.0.0.0-RC2Spring Cloud 2022.0.03.02022.0.0.0-RC1Spring Cloud 2022.0.03.0.02021.0.5.0*Spring Cloud 2021.0.52.6.132021.0.4…

js代码优化

感觉有点基础&#xff0c;不过还是记一下&#xff0c;遇到了至少有话说 语言特性 避免全局查找&#xff1a;在JavaScript中&#xff0c;全局变量的查找会比局部变量更耗时。因此&#xff0c;尽量将常用的变量存储为局部变量&#xff0c;以减少作用域链的查找时间。 避免过度使…

蓝桥杯上岸每日N题第三期(一)!!!

大家好 我是寸铁&#x1f4aa; 考前需要刷大量真题,大家一起相互监督&#xff0c;每日做N题&#xff0c;一起上岸吧✌️ ~ 冲刺蓝桥杯省一模板大全来啦 &#x1f4a5; ~ 蓝桥杯4月8号就要开始了 &#x1f64f; ~ 还没背熟模板的伙伴们背起来 &#x1f4aa; &#x1f4aa; &…

0基础学C#笔记03:进制转换

文章目录 前言一、十进制转二进制、八进制、十六进制1、类方法:使用Convert类方法ToString2、自己写:二、二进制、八进制、十六进制转十进制1、使用Convert类方法ToInt322、自己写经验总结扩展延伸1.十六进制转浮点数2、浮点数转十六进制数前言 首先我们知道在计算机当中所有…

uni-app 用法总结

1、跳转页面 this.$tab.navigateTo(/pages/mine/info/index) 2、接收跳转页面的参数 this.$tab.navigateTo(/pages/mine/info/index?abcccc) 获取页面传递的参数 this.$route.query.abc 3、动态设置导航标题 uni.setNavigationBarTitle({ // 接收到的title标题 …