轻量级的上拉/下拉刷新控件
- 与
UIRefreshControl
完全一致的接口调用方式,上手容易 - 面向协议编程,能够方便灵活地自定义视图
- 支持
UITableView
和UICollectionView
的上/下拉刷新,不占用HeaderView
和FooterView
- 预加载数据功能,当显示最后一个 cell 时,能够自动刷新后续数据,网络流畅时,用户看不到上拉视图,提供更加流畅的用户体验
- 无数据设置,当重复上拉刷新数据没有结果时,会停止上拉刷新,不会频繁发起网络请求
- iOS 8.0+
- Xcode 7.0
- 进入终端,
cd
到项目目录,输入以下命令,建立Podfile
$ pod init
- 在 Podfile 中输入以下内容:
platform :ios, '8.0'
use_frameworks!
target 'ProjectName' do
pod 'HMRefresh'
end
- 在终端中输入以下命令,安装或升级 Pod
# 安装 Pod,第一次使用
$ pod install
# 升级 Pod,后续使用
$ pod update
- 导入框架
@import HMRefresh;
- 在 TableViewController 的 viewDidLoad 中设置刷新控件
- (void)viewDidLoad {
[super viewDidLoad];
self.refreshControl = [[HMRefreshControl alloc] init];
[self.refreshControl addTarget:self action:@selector(loadData:) forControlEvents:UIControlEventValueChanged];
}
- 刷新数据方法
- (void)loadData:(HMRefreshControl *)refreshControl {
// 开始刷新
[refreshControl beginRefreshing];
[self.dataModal loadData:refreshControl.isPullupRefresh completion:^{
// 结束刷新
[refreshControl endRefreshing];
// 刷新数据
[self.tableView reloadData];
}];
}
- 使用 XIB 或 Storyboard 建立上拉/下拉刷新视图
- 在自定义视图的头文件中遵守协议
@interface DemoRefreshView : UIView <HMRefreshViewDelegate>
@end
- 代码连线到私有扩展中,注意删除
weak
修饰符
@property (nonatomic) IBOutlet UIActivityIndicatorView *refreshIndicator;
@property (nonatomic) IBOutlet UILabel *tipLabel;
@property (nonatomic) IBOutlet UIImageView *pulldownIcon;
@property (nonatomic) IBOutlet UILabel *timeLabel;
- 实现以下三个方法
@implementation DemoRefreshView
- (void)startAnimating {
[self.refreshIndicator startAnimating];
}
- (void)stopAnimating {
[self.refreshIndicator stopAnimating];
}
- (BOOL)isAnimating {
return self.refreshIndicator.isAnimating;
}
@end
- 导入框架
import HMRefresh
- 在 TableViewController 的 viewDidLoad 中设置刷新控件
override func viewDidLoad() {
super.viewDidLoad()
self.refreshControl = HMRefreshControl()
self.refreshControl?.addTarget(self, action: "loadData:", forControlEvents: .ValueChanged)
}
- 刷新数据方法
@objc private func loadData(refreshControl: HMRefreshControl) {
refreshControl.beginRefreshing()
dataModel.loadData(refreshControl.isPullupRefresh) {
refreshControl.endRefreshing()
self.tableView.reloadData();
}
}