【微信小程序开发】小程序中的上滑加载更多,下拉刷新是如何实现的?

小程序 0

在这里插入图片描述

✨✨ 欢迎大家来到景天科技苑✨✨

🎈🎈 养成好习惯,先赞后看哦~🎈🎈

🏆 作者简介:景天科技苑
🏆《头衔》:大厂架构师,华为云开发者社区专家博主,阿里云开发者社区专家博主,CSDN全栈领域优质创作者,掘金优秀博主,51CTO博客专家等。
🏆《博客》:Python全栈,前后端开发,小程序开发,人工智能,js逆向,App逆向,网络系统安全,数据分析,Django,fastapi,flask等框架,linux,shell脚本等实操经验,网站搭建,数据库等分享。

所属的专栏:微信小程序开发零基础教学,难点与应用实战总结
景天的主页:景天科技苑

文章目录

  • 1.上滑加载更多
  • 2.下拉刷新
  • 3.scroll-view实现上拉加载更多,下拉刷新

1.上滑加载更多

结合上一章我们的项目,先在原来的基础上添加个goods页面
在这里插入图片描述

js代码

Page({  data: {    good_list: [1, 2, 3]  },  // 当滑动到底部还有100rpx时,就会触发这个函数执行---》发送请求获取数据  onReachBottom() {    console.log('上拉了')    // 发送请求获取数据    wx.request({      url: 'http://127.0.0.1:8000/app01/random/',      method:'GET',      success:(res)=>{          this.setData({            good_list:this.data.good_list.concat(res.data)          })      }    })  },})

###wxml####

<view wx:for="{{good_list}}" wx:key="*this">{{item}}</view>

在这里插入图片描述

这样的123不好看没我们设置个样式
###wxss###

view{  height: 400rpx;  display: flex;  justify-content: center;  align-items: center;}/* 奇数背景色是粉色 */view:nth-child(odd){  background-color: pink;}/* 偶数背景色绿色 */view:nth-child(even){  background-color: rgb(17, 133, 88);}

在这里插入图片描述

现在我们要实现,往上拉,拉到最底部时,显示更多的数字
此时需要在goods.json文件中配置onReachBottomDistance

###json###

{  "usingComponents": {},  "onReachBottomDistance": 100}

onReachBottomDistance的意思是,当拉到距离底部距离多少rpx时开始触发加载更多
在这里插入图片描述

滑动加载数据,在js代码中是固定的函数名 onReachBottom

      // 当滑动到底部还有100rpx时,就会触发这个函数执行---》发送请求获取数据  onReachBottom() {    console.log('下拉了')    // 发送请求获取数据    wx.request({      url: 'http://127.0.0.1:8000/random',      method:'GET',      success:(res)=>{          this.setData({            good_list:this.data.good_list.concat(res.data)          })      }    })  },

django后端代码:
###url###
在这里插入图片描述

###视图###

import randomdef random_view(request):    l = []    for i in range(3):        l.append(random.randint(0, 99999))    return JsonResponse(l,safe=False)  # 返回json格式,如果里面有列表,必须加safe=False

后端运行
在这里插入图片描述

小程序上拉,显示更多数据
在这里插入图片描述

在这里插入图片描述

2.下拉刷新

上面我们讲到了下拉加载更多数据,如果我们想恢复到最初的默认怎么办,此时就用到了下拉刷新

###json中配置###

{  "usingComponents": {},  "onReachBottomDistance": 100,  "enablePullDownRefresh": true,  "backgroundColor": "#efefef",  "backgroundTextStyle":"dark"}

在这里插入图片描述

###wxml ###

<view wx:for="{{good_list}}" wx:key="*this">{{item}}</view>

###js ###

// 下拉刷新-onPullDownRefresh(){    console.log('下拉了,刷新')    // 只要下来,把数据恢复    this.setData({        good_list:[1,2,3]    })    // 下拉刷新后,loading效果回弹    if(this.data.good_list.length==3){        wx.stopPullDownRefresh()    }}

在这里插入图片描述

3.scroll-view实现上拉加载更多,下拉刷新

我们再新建个页面
在这里插入图片描述

重新建个tarbar
在这里插入图片描述

#####wxml####

<scroll-view class="scroll"scroll-y  # 运行y轴滑动lower-threshold="100" # 距离底部还有100px时,触发事件bindscrolltolower="handleGetData"# 事件处理函数refresher-enabled="true"        # 开启 下拉刷新refresher-default-style="black" # 下拉默认样式refresher-background="#f0f0f0"  # 下拉背景色bindrefresherrefresh="handleReload" # 下拉触发事件refresher-triggered="{{isRefresh}}" # 设置下拉回弹,false允许回弹,enable-back-to-top="true"  # 快速回到顶部,ios点顶部,安卓点tab>  <view wx:for="{{goods}}" wx:key="index">{{item}}</view></scroll-view>

在这里插入图片描述

###wxss###

.scroll{  /* 100vh就是指元素的高度等于当前浏览器的视窗高度,即浏览器内部的可视区域的高度大小 */  height: 100vh;   background-color: grey;}view{  height: 400rpx;  display: flex;  justify-content: center;  align-items: center;}/* 奇数 */view:nth-child(odd){  background-color: pink;}/* 偶数 */view:nth-child(even){  background-color: green;}

在这里插入图片描述

效果:
下拉刷新
在这里插入图片描述

上拉加载更多
在这里插入图片描述

也许您对下面的内容还感兴趣: