上一篇文章中,我们知道了使用 scroll-view 可以实现上拉加载更多,但是由于 scroll-view 的限制,它无法实现下拉加载更多,这篇文章我们使用 view 组件来实现 上拉和下拉加载更多。

下拉加载更多:

1、在响应的 xxx.json 配置文件依次配置如下配置

>> enablePullDownRefresh:true  表示开启下拉刷新

>> backgroundTextStyle              下拉 loading 的样式,仅支持 dark/light

>> backgroundColor                    窗口的背景色

2、上方后面2个没有设置好,在下拉时,页面顶部会出现一块白色的区域。

3、在下拉刷新时,不可使用 wx.showLoading 提示(其余的提示我没有测试),否则在 ios 下页面回弹过多,导致看不到顶部的那个提示页面刷新的区域。

4、页面下拉会触发 onPullDownRefresh 事件

5、防止 onPullDownRefresh 多次触发,导致多次请求

上拉加载更多:

1、在对应的 xxx.json 中配置(不是必须的)

>> onReachBottomDistance          页面上拉触底事件触发时距页面底部距离,单位为px

2、页面上拉在小于或等于  onReachBottomDistance  的距离时,会触发 onReachBottom 事件

实现效果:

代码实现:

1、页面布局 loadMore.wxml 文件的编写

<view class='view-container'>
<block wx:for='{{articles}}' wx:key='{{item.id}}'>
<view class='articles-container'>
<view class='info'>
<image class='avatar' src='{{item.avatar}}'></image>{{item.nickname}}
<text class='created-at'>{{item.created_at}}</text>
<text class='category'>{{item.category}}</text>
</view>
</view>
</block>
<view class='data-loading' hidden='{{hidden}}'>
数据加载中...
</view>
</view>

2、样式编写 loadMore.wxss 文件的编写

.view-container {
background-color: #fff;
} .data-loading {
height: 100rpx;
line-height: 100rpx;
background-color: #eee;
text-align: center;
font-size: 14px;
} .articles-container {
border-bottom: 1px solid #eee;
margin: 30rpx 10rpx;
background-color: #eee;
} .articles-container .info {
font-size: 12px;
margin: 20rpx 0rpx;
height: 100%;
display: inline-block;
} .articles-container .info .avatar {
width: 60rpx;
height: 60rpx;
margin-right: 10rpx;
border-radius: 60rpx;
display: inline-block;
vertical-align: middle;
} .articles-container .info .created-at {
margin: 0px 20rpx;
display: inline-block;
vertical-align: middle;
} .articles-container .info .category {
color: #3399ea;
display: inline-block;
vertical-align: middle;
}

3、js 控制 loadMore.js 文件的编写

Page({

  data: {
/**
* 需要访问的url
*/
urls: [
'https://www.csdn.net/api/articles?type=more&category=home&shown_offset=0',
'https://www.csdn.net/api/articles?type=new&category=arch',
'https://www.csdn.net/api/articles?type=new&category=ai',
'https://www.csdn.net/api/articles?type=new&category=newarticles'
],
/**
* 当前访问的url索引
*/
currentUrlIndex: 0,
/**
* 获取到的文章
*/
articles: [],
/**
* 控制上拉到底部时是否出现 "数据加载中..."
*/
hidden: true,
/**
* 数据是否正在加载中,避免数据多次加载
*/
loadingData: false
}, onLoad: function(options) {
this.loadData(false);
}, /**
* 加载数据
*/
loadData: function(tail, callback) {
var that = this,
urlIndex = that.data.currentUrlIndex;
wx.request({
url: that.data.urls[urlIndex],
success: function(r) {
var oldArticles = that.data.articles,
newArticles = tail ? oldArticles.concat(r.data.articles) : r.data.articles;
that.setData({
articles: newArticles,
currentUrlIndex: (urlIndex + 1) >= that.data.urls.length ? 0 : urlIndex + 1
});
if (callback) {
callback();
}
},
error: function(r) {
console.info('error', r);
},
complete: function() {}
});
}, /**
* 监听用户下拉动作
*/
onPullDownRefresh: function() {
console.info('onPullDownRefresh');
var loadingData = this.data.loadingData,
that = this;
if (loadingData) {
return;
}
// 显示导航条加载动画
wx.showNavigationBarLoading();
// 显示 loading 提示框,在 ios 系统下,会导致顶部的加载的三个点看不见
// wx.showLoading({
// title: '数据加载中...',
// });
setTimeout(function() {
that.loadData(false, () => {
that.setData({
loadingData: false
});
wx.stopPullDownRefresh();
// wx.hideLoading();
wx.hideNavigationBarLoading();
console.info('下拉数据加载完成.');
});
}, 1000);
}, /**
* 页面上拉触底事件的处理函数
*/
onReachBottom: function() {
console.info('onReachBottom');
var hidden = this.data.hidden,
loadingData = this.data.loadingData,
that = this;
if (hidden) {
this.setData({
hidden: false
});
console.info(this.data.hidden);
}
if (loadingData) {
return;
}
this.setData({
loadingData: true
});
// 加载数据,模拟耗时操作 wx.showLoading({
title: '数据加载中...',
}); setTimeout(function() {
that.loadData(true, () => {
that.setData({
hidden: true,
loadingData: false
});
wx.hideLoading();
});
console.info('上拉数据加载完成.');
}, 1000);
}
})

4、配置文件 loadMore.json 的编写

{
"navigationBarTitleText": "上拉刷新和下拉加载更多",
"enablePullDownRefresh": true,
"onReachBottomDistance": 0,
"backgroundTextStyle": "dark",
"backgroundColor": "#c0d9ff"
}

完整代码:

微信小程序实现上拉和下拉加载更多代码:https://gitee.com/huan1993/weixin_mini_program_study/tree/master/pages/view-pull-up-load-more

微信小程序实现上拉和下拉加载更多的更多相关文章

  1. 微信小程序中如何实现分页下拉加载?(附源码)

    转眼间坚持写教你微信小程序系列已经有十节系列课程了,每天的工作压力繁重,小女子也不知道自己还能坚持这样的系列教程多久.只希望每篇教程真的对大家有帮助.这节课我们要介绍的就是如何实现分页的下拉加载,我们 ...

  2. 微信小程序 在使用wx.request时显示加载中

    微信小程序中,向后台请求数据是,通常想给用户提示正在加载中,如下图: 我们可以用wx.showLoading(OBJECT),当请求服务器的地方多了,怎么才能不每次都要去调用函数,我们只要对wx.re ...

  3. 微信小程序开发--模板(template)使用,数据加载,点击交互

    微信小程序视图层提供了 模板(template),可以在模板中定义代码片段,然后在不同的地方调用.结果在数据渲染那懵逼了.按照官网上对模板的说明和对数据的加载. 1.定义模板 使用name属性,作为模 ...

  4. 在微信小程序中,如何实现下拉刷新(模拟刷新)

    一.在app.json中启动刷新, 在Windows 中, 添加  "enablePullDownRefresh":"true" 二.在需要刷新的页面中写(若是 ...

  5. 【微信小程序】scroll-view与Page下拉冲突

    需求:主界面是个列表.列表可以纵向滑动,下拉添加新的条目Item.每个条目Item可以横向滑动. 发现做下拉时,用Page的enablePullDownRefresh和scroll-view条目的横向 ...

  6. 微信小程序开发——设置默认图片、错误加载图片

    小程序不支持h5中的onerrorimg,只开放了binderror属性,当错误发生时,会发布到 AppService,事件对象event.detail = {errMsg: 'something w ...

  7. 微信小程序(五) 利用模板动态加载数据

    利用模板动态加载数据,其实是对上一节静态数据替换成动态数据:

  8. 微信小程序:picker组件实现下拉框效果

    一.wxml中代码 <view class="in_order_Param">             <text>状态:</text>     ...

  9. 微信小程序 和 laravel8 实现搜索后分页 加载

    Page({ /** * 页面的初始数据 */ data: { activity:{}, page:1, last_page : 0, keyword:'' }, //加载 scroll(e){ le ...

随机推荐

  1. 通过url把第一个页面的数据传到第二页面

    第一个页面: function GetQueryString(name) { var reg = new RegExp("(^|&)"+ name +"=([^& ...

  2. [第十六篇]——Docker 安装 CentOS之Spring Cloud直播商城 b2b2c电子商务技术总结

    Docker 安装 CentOS CentOS(Community Enterprise Operating System)是 Linux 发行版之一,它是来自于 Red Hat Enterprise ...

  3. 优雅的编码,使用Optional代替if-else

    Optional是JAVA8引入的类,它其实是一个包装类,可以对所有对象进行包装, 包括null,这个特性使得我们编码可以优雅的解决空指针异常. 先编写一些测试类 class Student { pr ...

  4. div居中和垂直居中的最简单方法

    div居中方法: 1)对父盒子添加 text-align="center": 2)子盒子添加 margin:0 auto; 例子: body{text-align:center} ...

  5. oracle 基础SQL语句 版本5.7.29

    一.表与用户介绍 oracle安装完成后默认会有很多用户,大致分为2类用户:一类是必需的帐户,一类是存储各种应用的帐户,默认密码如下: oracle自带的也会有很多默认表存在: 二.创建用户.创建表空 ...

  6. K8s一键安装

    安装案例: 系统:Centos可以多台Master(Master不能低于3台)多台Node此案例使用三台Master两台Node,用户名root,密码均为123456 master 192.168.2 ...

  7. centos7配置bind重启后错误解决

    最近研究centos7安装bind做DNS服务器,都配置好了后,重启后用systemctl status named 发现好多诸如以下错误:error (network unreachable) re ...

  8. 关于Python中的深浅拷贝

    之前一直认为浅拷贝是拷贝内容的第一层,但是不开辟内存,只是增加新的指向原来的内容:深拷贝是拷贝是拷贝每一层并开辟内存. 其实这个是不严谨的不正确的. 从以上可以看出,浅拷贝中当时可变类型的时候,内存是 ...

  9. sonar入门

    一.Sonar是什么? 根据我的了解,可以说Sonar包含三个部分: SonarQube是一种自动代码审查工具,用于检测代码中的错误,漏洞和代码味道.它可以与您现有的工作流程集成,以实现跨项目分支和提 ...

  10. 5分钟实现用docker搭建Redis集群模式和哨兵模式

    如果让你为开发.测试环境分别搭一套哨兵和集群模式的redis,你最快需要多久,或许你需要一天?2小时?事实是可以更短. 是的,你已经猜到了,用docker部署,真的只需要十几分钟. 一.准备工作 拉取 ...