`
阅读更多

    在上一篇文章中,我们知道了使用 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

  • 大小: 5.2 MB
分享到:
评论

相关推荐

    微信小程序-微信小程序实现类似android下拉刷新上拉加载更多ListView.zip

    在微信小程序中,开发者可以创建出与Android应用中类似的下拉刷新和上拉加载更多的功能,这极大地提升了用户体验,使得用户能够方便地查看和获取更多数据。本项目着重讲解如何在微信小程序中实现这一功能,结合Java...

    微信小程序例子 下拉加载更多

    在“微信小程序例子 - 下拉加载更多”这个项目中,我们主要探讨的是如何在微信小程序中实现下拉刷新和上拉加载更多的功能,这在数据流丰富的应用中非常常见,如社交媒体、电商应用等。 1. **下拉加载**:当用户滚动...

    微信小程序列表下拉刷新加载更多

    综上所述,实现微信小程序列表的下拉刷新加载更多功能,需要熟练掌握微信小程序的生命周期、数据管理、网络请求、列表渲染、动画效果、状态管理、页面配置、错误处理、性能优化以及设备适配等多个方面。通过合理的...

    微信小程序_上拉加载更多_demo

    在微信小程序中,"上拉加载更多"是一种常见的功能,用于实现滚动页面时自动加载更多数据,提高用户体验,尤其在内容丰富的列表或流式布局中应用广泛。 在微信小程序中实现上拉加载更多的功能,主要涉及到以下几个...

    微信小程序-微信小程序实现类似android下拉刷新上拉加载更多ListView

    本项目"微信小程序-微信小程序实现类似android下拉刷新上拉加载更多ListView"是针对微信小程序的一个功能实现,目的是在小程序中复现Android中常见的ListView的下拉刷新和上拉加载更多的功能。 在Android开发中,...

    小程序swiper实现tab切换--下拉刷新、上拉加载更多.zip

    本项目中,开发者利用Swiper和Swiper-Item组件,结合下拉刷新和上拉加载更多的功能,构建了一个交互性强、用户体验良好的小程序界面。 1. **Swiper组件**: Swiper是微信小程序中的一个容器组件,可以用来展示一...

    微信小程序-微信小程序里的listview,内置了上拉刷新下拉加载更多的功能

    微信小程序里的listview,内置了上拉刷新下拉加载更多的功能,以及页面状态显示 适用于页面内有一个可上拉刷新下拉加载的list的情况 使用 1.拷贝lib文件夹到根目录 2.拷贝utils中的lvUtil和netUtil到你的utils文件夹 3...

    微信小程序UI 上拉加载 下拉刷新的实现.rar

    微信小程序UI设计实例,今天分享给大家的是上拉加载 下拉刷新,这个功能在微信中还是比较常见的,大家也习惯了操作时候下拉屏幕刷新内容,上拉则加载更多内容,这个功能在Android智能机上已经得到了很好的应用,这个...

    微信小程序学习用demo:cnode:API使用与下拉加载更多(源代码+截图)

    微信小程序学习用demo:cnode:API使用与下拉加载更多(源代码+截图)微信小程序学习用demo:cnode:API使用与下拉加载更多(源代码+截图)微信小程序学习用demo:cnode:API使用与下拉加载更多(源代码+截图)微信小程序...

    微信小程序实现下拉加载更多的源码

    oadmore 加载更多(分页加载) 当用户打开一个页面时,假设后台数据量庞大时,一次性地返回所有数据给客户端,页面的打开速度就会有所下降,而且用户只看上面的内容而...列表滚动到底部时,继续往上拉,加载更多内容

    微信小程序-实现瀑布流布局demo源代码

    本教程将通过一个具体的实例——“微信小程序-实现瀑布流布局demo”来探讨如何在微信小程序中实现瀑布流布局和无限下拉加载功能。 首先,我们要理解瀑布流布局。这是一种常见的网页设计布局方式,其特点是以多列...

    微信小程序,使用scroll-view实现下拉加载更多(下一页)源码

    综上所述,利用微信小程序的`scroll-view`组件结合适当的事件监听和数据管理,可以轻松实现下拉加载更多功能。通过不断学习和实践,开发者可以更好地理解和运用这些技术,提升小程序的用户体验。

    微信小程序实现列表的上拉刷新和上拉加载

    在微信小程序中,实现列表的上拉刷新和上拉加载是常见的功能,它极大地提升了用户体验,使得用户可以方便地获取更多的数据。这个功能主要依赖于微信小程序提供的`onReachBottom`事件和`wx.startPullDownRefresh`方法...

    03微信小程序上拉加载和微信小程序分页的功能.pptx

    在学习微信小程序的下拉刷新和加载更多功能时,我们需要明确以下几个关键知识点: 1. 微信小程序的生命周期函数,特别是onReachBottom函数的作用和使用方式。 2. 分页加载的原理和优势,以及如何根据用户操作上拉...

    微信小程序-模仿APP(上拉加载更多,下拉刷新)Demo

    在微信小程序开发中,"上拉加载更多"和"下拉刷新"是常见的用户体验功能,它们使得用户在浏览内容时可以方便地获取更多的信息或更新数据。本项目提供了一个微信小程序的示例,用于演示如何实现这两种交互效果,从而...

    微信小程序,两种方式实现上拉加载,下拉刷新

    通过以上代码,你可以实现在微信小程序中下拉刷新和上拉加载的功能。记得根据实际情况调整数据加载的逻辑,如网络请求、数据处理等。同时,为了优化用户体验,可以考虑在数据请求过程中显示加载指示器,并在请求完成...

    微信小程序下拉刷新上拉加载组件.zip

    本压缩包“微信小程序下拉刷新上拉加载组件.zip”包含了一个关于微信小程序中两个关键交互功能——下拉刷新(Pull-down Refresh)和上拉加载更多(Load More on Pull-up)的实现资源。这两个功能是提升用户体验的...

    微信小程序源码-仿酷狗音乐微信小程序

    2. 歌曲列表展示:通过异步请求获取音乐列表数据,使用WXML动态渲染列表,实现滑动加载更多功能。同时,需要处理用户点击歌曲时的选中状态和播放控制。 3. 搜索功能:实现关键词搜索,可能需要对接酷狗音乐的公开...

    基于微信小程序实现二十四节气小程序小程序源码分享

    例如,可以使用下拉刷新和上拉加载更多的功能,使内容分页加载,提高性能。 7. **发布与更新**:完成开发后,开发者需要在微信开发者工具中进行预览、调试和上传代码到微信小程序后台,经过审核后,用户就能在微信...

    微信小程序Demo--吃货APP(上拉加载更多,下拉刷新)-附完整源代码.rar

    微信小程序Demo–吃货APP(上拉加载更多,下拉刷新)是一个功能丰富且易于定制的源码项目。它为开发者提供了一个直观的平台,用于学习、实践以及优化小程序开发中的各种关键技术。 该Demo的核心功能围绕“吃货”...

Global site tag (gtag.js) - Google Analytics