赞
踩
项目主页地址:MJRefresh
项目下载地址:点击下载
适用范围:可用于常见控件 UIScrollView
、UITableView
、UICollectionView
、UIWebView 实现上拉刷新和下拉加载的效果。
加入项目方式:
CocoaPods安装:pod 'MJRefresh'
手动加入:将MJRefresh文件夹下所有文件拖入项目,使用时候 #import "MJRefresh.h"即可。
文件结构:
- /** 刷新控件的基类 */
- @interface MJRefreshComponent : UIView
- #pragma mark - 刷新状态控制
- /** 进入刷新状态 */
- - (void)beginRefreshing;
- /** 结束刷新状态 */
- - (void)endRefreshing;
- /** 是否正在刷新 */
- - (BOOL)isRefreshing;
-
- #pragma mark - 其他
- /** 根据拖拽比例自动切换透明度 */
- @property (assign, nonatomic, getter=isAutomaticallyChangeAlpha) BOOL automaticallyChangeAlpha;
- @end
- // 下拉刷新控件:负责监控用户下拉的状态
- @interface MJRefreshHeader : MJRefreshComponent
- /** 创建header */
- + (instancetype)headerWithRefreshingBlock:(MJRefreshComponentRefreshingBlock)refreshingBlock;
- /** 创建header */
- + (instancetype)headerWithRefreshingTarget:(id)target refreshingAction:(SEL)action;
- /** 这个key用来存储上一次下拉刷新成功的时间 */
- @property (copy, nonatomic) NSString *lastUpdatedTimeKey;
- /** 上一次下拉刷新成功的时间 */
- @property (strong, nonatomic, readonly) NSDate *lastUpdatedTime;
- /** 忽略多少scrollView的contentInset的top */
- @property (assign, nonatomic) CGFloat ignoredScrollViewContentInsetTop;
- @end
- // 上拉刷新控件
- @interface MJRefreshFooter : MJRefreshComponent
- /** 创建footer */
- + (instancetype)footerWithRefreshingBlock:(MJRefreshComponentRefreshingBlock)refreshingBlock;
- /** 创建footer */
- + (instancetype)footerWithRefreshingTarget:(id)target refreshingAction:(SEL)action;
-
- /** 提示没有更多的数据 */
- - (void)endRefreshingWithNoMoreData;
- - (void)noticeNoMoreData MJRefreshDeprecated("使用endRefreshingWithNoMoreData");
-
- /** 重置没有更多的数据(消除没有更多数据的状态) */
- - (void)resetNoMoreData;
-
- /** 忽略多少scrollView的contentInset的bottom */
- @property (assign, nonatomic) CGFloat ignoredScrollViewContentInsetBottom;
-
- /** 自动根据有无数据来显示和隐藏(有数据就显示,没有数据隐藏。默认是NO) */
- @property (assign, nonatomic, getter=isAutomaticallyHidden) BOOL automaticallyHidden MJRefreshDeprecated("不建议使用此属性,开发者请自行控制footer的显示和隐藏。基于安全考虑,在未来的某些版本此属性可能作废");
- @end

- @interface MJRefreshAutoFooter : MJRefreshFooter
- /** 是否自动刷新(默认为YES) */
- @property (assign, nonatomic, getter=isAutomaticallyRefresh) BOOL automaticallyRefresh;
-
- /** 当底部控件出现多少时就自动刷新(默认为1.0,也就是底部控件完全出现时,才会自动刷新) */
- @property (assign, nonatomic) CGFloat appearencePercentTriggerAutoRefresh MJRefreshDeprecated("请使用triggerAutomaticallyRefreshPercent属性");
-
- /** 当底部控件出现多少时就自动刷新(默认为1.0,也就是底部控件完全出现时,才会自动刷新) */
- @property (assign, nonatomic) CGFloat triggerAutomaticallyRefreshPercent;
-
- /** 是否每一次拖拽只发一次请求 */
- @property (assign, nonatomic, getter=isOnlyRefreshPerDrag) BOOL onlyRefreshPerDrag;
- @end
下拉刷新01-默认
- self.tableView.header = [MJRefreshNormalHeader headerWithRefreshingBlock:^{
- // 进入刷新状态后会自动调用这个block
- }];
- 或
- // 设置回调(一旦进入刷新状态,就调用target的action,也就是调用self的loadNewData方法)
- self.tableView.header = [MJRefreshNormalHeader headerWithRefreshingTarget:self refreshingAction:@selector(loadNewData)];
- // 马上进入刷新状态
- [self.tableView.header beginRefreshing];
下拉刷新02-动画图片
- // 设置回调(一旦进入刷新状态,就调用target的action,也就是调用self的loadNewData方法)
- MJRefreshGifHeader *header = [MJRefreshGifHeader headerWithRefreshingTarget:self refreshingAction:@selector(loadNewData)];
- // 设置普通状态的动画图片
- [header setImages:idleImages forState:MJRefreshStateIdle];
- // 设置即将刷新状态的动画图片(一松开就会刷新的状态)
- [header setImages:pullingImages forState:MJRefreshStatePulling];
- // 设置正在刷新状态的动画图片
- [header setImages:refreshingImages forState:MJRefreshStateRefreshing];
- // 设置header
- self.tableView.header = header;
下拉刷新03-隐藏时间
- // 隐藏时间
- header.lastUpdatedTimeLabel.hidden = YES;
下拉刷新04-隐藏状态和时间
- // 隐藏时间
- header.lastUpdatedTimeLabel.hidden = YES;
-
- // 隐藏状态
- header.stateLabel.hidden = YES;
下拉刷新05-自定义文字
- // 设置文字
- [header setTitle:@"Pull down to refresh" forState:MJRefreshStateIdle];
- [header setTitle:@"Release to refresh" forState:MJRefreshStatePulling];
- [header setTitle:@"Loading ..." forState:MJRefreshStateRefreshing];
-
- // 设置字体
- header.stateLabel.font = [UIFont systemFontOfSize:15];
- header.lastUpdatedTimeLabel.font = [UIFont systemFontOfSize:14];
-
- // 设置颜色
- header.stateLabel.textColor = [UIColor redColor];
- header.lastUpdatedTimeLabel.textColor = [UIColor blueColor];
下拉刷新06-自定义刷新控件
- self.tableView.header = [MJDIYHeader headerWithRefreshingTarget:self refreshingAction:@selector(loadNewData)];
- // 具体实现参考MJDIYHeader.h和MJDIYHeader.m
上拉刷新01-默认
- self.tableView.footer = [MJRefreshAutoNormalFooter footerWithRefreshingBlock:^{
- // 进入刷新状态后会自动调用这个block
- }];
- 或
- // 设置回调(一旦进入刷新状态,就调用target的action,也就是调用self的loadMoreData方法)
- self.tableView.footer = [MJRefreshAutoNormalFooter footerWithRefreshingTarget:self refreshingAction:@selector(loadMoreData)];
上拉刷新02-动画图片
- // 设置回调(一旦进入刷新状态,就调用target的action,也就是调用self的loadMoreData方法)
- MJRefreshAutoGifFooter *footer = [MJRefreshAutoGifFooter footerWithRefreshingTarget:self refreshingAction:@selector(loadMoreData)];
-
- // 设置刷新图片
- [footer setImages:refreshingImages forState:MJRefreshStateRefreshing];
-
- // 设置尾部
- self.tableView.footer = footer;
上拉刷新03-隐藏刷新状态的文字
- // 隐藏刷新状态的文字
- footer.refreshingTitleHidden = YES;
- // 如果没有上面的方法,就用footer.stateLabel.hidden = YES;
上拉刷新04-全部加载完毕
- // 变为没有更多数据的状态
- [footer noticeNoMoreData];
上拉刷新05-自定义文字
- // 设置文字
- [footer setTitle:@"Click or drag up to refresh" forState:MJRefreshStateIdle];
- [footer setTitle:@"Loading more ..." forState:MJRefreshStateRefreshing];
- [footer setTitle:@"No more data" forState:MJRefreshStateNoMoreData];
-
- // 设置字体
- footer.stateLabel.font = [UIFont systemFontOfSize:17];
-
- // 设置颜色
- footer.stateLabel.textColor = [UIColor blueColor];
上拉刷新06-加载后隐藏
- // 隐藏当前的上拉刷新控件
- self.tableView.footer.hidden = YES;
上拉刷新07-自动回弹的上拉01
self.tableView.footer = [MJRefreshBackNormalFooter footerWithRefreshingTarget:self refreshingAction:@selector(loadMoreData)];
上拉刷新08-自动回弹的上拉02
- MJRefreshBackGifFooter *footer = [MJRefreshBackGifFooter footerWithRefreshingTarget:self refreshingAction:@selector(loadMoreData)];
-
- // 设置普通状态的动画图片
- [footer setImages:idleImages forState:MJRefreshStateIdle];
- // 设置即将刷新状态的动画图片(一松开就会刷新的状态)
- [footer setImages:pullingImages forState:MJRefreshStatePulling];
- // 设置正在刷新状态的动画图片
- [footer setImages:refreshingImages forState:MJRefreshStateRefreshing];
-
- // 设置尾部
- self.tableView.footer = footer;
上拉刷新09-自定义刷新控件(自动刷新)
- self.tableView.footer = [MJDIYAutoFooter footerWithRefreshingTarget:self refreshingAction:@selector(loadMoreData)];
- // 具体实现参考MJDIYAutoFooter.h和MJDIYAutoFooter.m
上拉刷新10-自定义刷新控件(自动回弹)
- self.tableView.footer = [MJDIYBackFooter footerWithRefreshingTarget:self refreshingAction:@selector(loadMoreData)];
- // 具体实现参考MJDIYBackFooter.h和MJDIYBackFooter.m
UICollectionView01-上下拉刷新
- // 下拉刷新
- self.collectionView.header = [MJRefreshNormalHeader headerWithRefreshingBlock:^{
- // 进入刷新状态后会自动调用这个block
- }];
- // 上拉刷新
- self.collectionView.footer = [MJRefreshAutoNormalFooter footerWithRefreshingBlock:^{
- // 进入刷新状态后会自动调用这个block
- }];
UIWebView01-下拉刷新
-
- // 添加下拉刷新控件
- self.webView.scrollView.header = [MJRefreshNormalHeader headerWithRefreshingBlock:^{
- // 进入刷新状态后会自动调用这个block
- }];
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。