服务器之家:专注于服务器技术及软件下载分享
分类导航

PHP教程|ASP.NET教程|Java教程|ASP教程|编程技术|正则表达式|C/C++|IOS|C#|Swift|Android|VB|R语言|JavaScript|易语言|vb.net|

服务器之家 - 编程语言 - Swift - Swift快速集成下拉刷新和上拉加载更多示例代码

Swift快速集成下拉刷新和上拉加载更多示例代码

2021-01-05 14:52eggswift Swift

这篇文章主要介绍了Swift快速集成下拉刷新和上拉加载更多示例代码,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

ESPullToRefresh

ESPullToRefresh是一个非常易于开发者使用的下拉刷新和加载更多组件。通过一个UIScrollView的扩展,可以轻松为UIScrollView的所有子类添加下拉刷新功能。 如果你想定制组件的UI样式,只要实现指定的协议方法即可。Github地址

如何安装

使用CocoaPods

?
1
pod "ESPullToRefresh"

手动安装

?
1
2
git clone https://github.com/eggswift/pull-to-refresh.git
open ESPullToRefresh

开始使用

使用默认样式 效果如下:

Swift快速集成下拉刷新和上拉加载更多示例代码

设置默认下拉刷新组件

?
1
2
3
4
5
6
7
8
9
10
self.tableView.es_addPullToRefresh {
  [weak self] in
  /// 在这里做刷新相关事件
  /// ...
  /// 如果你的刷新事件成功,设置completion自动重置footer的状态
  self?.tableView.es_stopPullToRefresh(completion: true)
  /// 设置ignoreFooter来处理不需要显示footer的情况
  self?.tableView.es_stopPullToRefresh(completion: true, ignoreFooter: false)
  })
}

设置默认加载更多组件

?
1
2
3
4
5
6
7
8
9
10
self.tableView.es_addInfiniteScrolling {
  [weak self] in
  /// 在这里做加载更多相关事件
  /// ...
  /// 如果你的加载更多事件成功,调用es_stopLoadingMore()重置footer状态
  self?.tableView.es_stopLoadingMore()
  /// 通过es_noticeNoMoreData()设置footer暂无数据状态
  self?.tableView.es_noticeNoMoreData()
  })
}

使用自定义样式 效果如下:

Swift快速集成下拉刷新和上拉加载更多示例代码

注: 加载动画资源来自美团 iOS app。

Swift快速集成下拉刷新和上拉加载更多示例代码

ESPullToRefresh通过ESRefreshProtocol和ESRefreshAnimatorProtocol来约束刷新组件的使用,自定义的组件必须遵守这两个协议,并实现协议中的方法。

设置自定义下拉刷新组件

?
1
2
func es_addPullToRefresh(animator animator: protocol<ESRefreshProtocol, ESRefreshAnimatorProtocol>,
handler: ESRefreshHandler)

设置自定义加载更多组件

?
1
2
func es_addInfiniteScrolling(animator animator: protocol<ESRefreshProtocol, ESRefreshAnimatorProtocol>,
handler: ESRefreshHandler)

移除方法

?
1
2
func es_removeRefreshHeader()
func es_removeRefreshFooter()

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持服务器之家。

原文链接:http://www.jianshu.com/p/c5bc2d8c68e4?utm_source=tuicool&utm_medium=referral#

延伸 · 阅读

精彩推荐