Swift快速集成下拉刷新和上拉加载更多

ESPullToRefresh

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

如何安装

使用CocoaPods

pod "ESPullToRefresh"

手动安装

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

开始使用

使用默认样式 效果如下:

example_default.gif

设置默认下拉刷新组件

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)
    })
}

设置默认加载更多组件

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

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

example_meituan.gif

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

example_wechat.gif

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

设置自定义下拉刷新组件

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

设置自定义加载更多组件

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

移除方法

func es_removeRefreshHeader()
func es_removeRefreshFooter()

如果在使用中有什么疑问,可以随时@我

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 175,067评论 25 709
  • 发现 关注 消息 iOS 第三方库、插件、知名博客总结 作者大灰狼的小绵羊哥哥关注 2017.06.26 09:4...
    肇东周阅读 14,194评论 4 61
  • ·第八次 万禺醒在了一个陌生的地方。 漫天都是粉色的花在飘,还有风吹着树枝,在动、在响。 一个女人站在这样的景象里...
    八风动阅读 3,860评论 0 3
  • 亲爱的家长您好,我是快乐筒话小主持特训班的小语老师。今天是宝贝第一次上小主持特训班课程,表现棒棒哒!我们的...
    快乐筒话小主持学院阅读 4,457评论 0 1
  • 早餐昨晚的包子和半个地瓜,午餐炸汤圆,晚餐海螺一盘 今天在家看两岁半的大外甥,也许因为儿子3岁前我和先生工作原因没...
    妮儿_ebf9阅读 832评论 4 2