MJRefresh小解析

框架結(jié)構(gòu)

1.框架結(jié)構(gòu)圖

image.png

2.MJRefresh的框架圖梳理

作用
MJRefreshComponent 繼承自UIView贬丛,最基本的刷新類
MJRefreshHeader 最基本的下拉刷新類
MJRefreshStateHeader 可以下拉刷新,但是只有文字
MJRefreshNormalHeader 默認(rèn)的刷新樣式氧猬,有文字壁涎,有上下箭頭,有菊花

對于使用下拉刷新的問題是一定要自定義控件的,畢竟各個App的風(fēng)格截然不同

使用說明

1.MJRefresh默認(rèn)的下拉刷新和上拉加載

使用@selector的方式

- (void)viewDidLoad {
    [super viewDidLoad];
    // Do any additional setup after loading the view.

    //默認(rèn)【下拉刷新】
    self.tableView.mj_header = [MJRefreshNormalHeader headerWithRefreshingTarget:self refreshingAction:@selector(refresh)];
    //默認(rèn)【上拉加載】
    self.tableView.mj_footer = [MJRefreshAutoNormalFooter footerWithRefreshingTarget:self refreshingAction:@selector(loadMore)];
}
- (void)refresh {
    [self getNetworkData:YES];
}
- (void)loadMore {
    [self getNetworkData:NO];
}

使用block的方式

- (void)viewDidLoad {
    [super viewDidLoad];
    // Do any additional setup after loading the view.

    __weak typeof(self) weakSelf = self;
    //默認(rèn)block方法:設(shè)置下拉刷新
    self.tableView.mj_header = [MJRefreshNormalHeader headerWithRefreshingBlock:^{
        [weakSelf getNetworkData:YES];
    }];

    //默認(rèn)block方法:設(shè)置上拉加載更多
    self.tableView.mj_footer = [MJRefreshAutoNormalFooter footerWithRefreshingBlock:^{
        //Call this Block When enter the refresh status automatically
        [weakSelf getNetworkData:NO];
    }];

}

自定義下拉刷新和上拉加載

1.動畫圖片樣式山林;
2.隱藏刷新控件狀態(tài)或者時間樣式房待;
3.自定義刷新狀態(tài)和刷新時間文字樣式

- (void)viewDidLoad {
    [super viewDidLoad];
    //樣式一:設(shè)置一張圖片(無動畫效果)
//    NSArray *idleImages = [NSArray arrayWithObject:[UIImage imageNamed:@"xiala_icon.png"]];
    //樣式二:設(shè)置多張圖片(有動畫效果)
    NSArray *idleImages = [NSArray arrayWithObjects:
                           [UIImage imageNamed:@"dropdown_loading_01.png"],
                           [UIImage imageNamed:@"dropdown_loading_02.png"],
                           [UIImage imageNamed:@"dropdown_loading_03.png"],nil];

    NSArray *pullingImages = [NSArray arrayWithObject:[UIImage imageNamed:@"shifang_icon.png"]];
    NSArray *refreshingImages = [NSArray arrayWithObjects:
                                 [UIImage imageNamed:@"load_view_01.png"],
                                 [UIImage imageNamed:@"load_view_02.png"],
                                 [UIImage imageNamed:@"load_view_03.png"],
                                 [UIImage imageNamed:@"load_view_04.png"],
                                 [UIImage imageNamed:@"load_view_05.png"],
                                 [UIImage imageNamed:@"load_view_06.png"],
                                 [UIImage imageNamed:@"load_view_07.png"],
                                 [UIImage imageNamed:@"load_view_08.png"],
                                 [UIImage imageNamed:@"load_view_09.png"],
                                 [UIImage imageNamed:@"load_view_010.png"], nil];

//    MJRefreshGifHeader *header = [MJRefreshGifHeader headerWithRefreshingTarget:self refreshingAction:@selector(animationRefresh)];

    //-------以下是使用block方法【不包含animationRefresh方法】,動畫設(shè)置在上面的部分代碼---------

    __weak typeof(self) weakSelf = self;
    MJRefreshGifHeader *header = [MJRefreshGifHeader headerWithRefreshingBlock:^{
        [weakSelf getNetworkData:YES];
    }];

    //-------以上是使用block方法【不包含animationRefresh方法】,動畫設(shè)置在上面的部分代碼---------

    //1.設(shè)置普通狀態(tài)的動畫圖片
    [header setImages:idleImages forState:MJRefreshStateIdle];
    //2.設(shè)置即將刷新狀態(tài)的動畫圖片(一松開就會刷新的狀態(tài))
    [header setImages:pullingImages forState:MJRefreshStatePulling];
    //3.設(shè)置正在刷新狀態(tài)的動畫圖片
    [header setImages:refreshingImages forState:MJRefreshStateRefreshing];

    self.tableView.mj_header = header;

#pragma mark --- 下面兩個設(shè)置根據(jù)各自需求設(shè)置
//    // 隱藏更新時間
//    header.lastUpdatedTimeLabel.hidden = YES;
//    
//    // 隱藏刷新狀態(tài)
//    header.stateLabel.hidden = YES;

#pragma mark --- 自定義刷新狀態(tài)和刷新時間文字【當(dāng)然了,對應(yīng)的Label不能隱藏】
    // Set title
    [header setTitle:@"Pull down to refresh" forState:MJRefreshStateIdle];
    [header setTitle:@"Release to refresh" forState:MJRefreshStatePulling];
    [header setTitle:@"Loading ..." forState:MJRefreshStateRefreshing];

    // Set font
    header.stateLabel.font = [UIFont systemFontOfSize:15];
    header.lastUpdatedTimeLabel.font = [UIFont systemFontOfSize:14];

    // Set textColor
    header.stateLabel.textColor = [UIColor redColor];
    header.lastUpdatedTimeLabel.textColor = [UIColor blueColor];

}
#pragma mark --- "動畫圖片"樣式的非block方法
-(void)animationRefresh
{
    [self getNetworkData:YES];
}

完全自定義的下拉刷新和上拉加載

  1. 首先創(chuàng)建一個類(譬如MJDIYHeader)驼抹,繼承自MJRefreshHeader桑孩;
  2. 重寫相關(guān)方法 【 在MJRefreshComponent.h中有下面的提示】
#pragma mark - 交給子類們?nèi)?shí)現(xiàn)
/** 初始化 */
#pragma mark 在這里做一些初始化配置(比如添加子控件)
-(void)prepare NS_REQUIRES_SUPER;
/** 擺放子控件frame */
#pragma mark 在這里設(shè)置子控件的位置和尺寸
-(void)placeSubviews NS_REQUIRES_SUPER;
/** 當(dāng)scrollView的contentOffset發(fā)生改變的時候調(diào)用 */
-(void)scrollViewContentOffsetDidChange:(NSDictionary *)change NS_REQUIRES_SUPER;
/** 當(dāng)scrollView的contentSize發(fā)生改變的時候調(diào)用 */
-(void)scrollViewContentSizeDidChange:(NSDictionary *)change NS_REQUIRES_SUPER;
/** 當(dāng)scrollView的拖拽狀態(tài)發(fā)生改變的時候調(diào)用 */
-(void)scrollViewPanStateDidChange:(NSDictionary *)change NS_REQUIRES_SUPER;
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市框冀,隨后出現(xiàn)的幾起案子流椒,更是在濱河造成了極大的恐慌,老刑警劉巖明也,帶你破解...
    沈念sama閱讀 217,826評論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件宣虾,死亡現(xiàn)場離奇詭異惯裕,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)绣硝,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,968評論 3 395
  • 文/潘曉璐 我一進(jìn)店門蜻势,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人鹉胖,你說我怎么就攤上這事咙边。” “怎么了次员?”我有些...
    開封第一講書人閱讀 164,234評論 0 354
  • 文/不壞的土叔 我叫張陵败许,是天一觀的道長。 經(jīng)常有香客問我淑蔚,道長市殷,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,562評論 1 293
  • 正文 為了忘掉前任刹衫,我火速辦了婚禮醋寝,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘带迟。我一直安慰自己音羞,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,611評論 6 392
  • 文/花漫 我一把揭開白布仓犬。 她就那樣靜靜地躺著嗅绰,像睡著了一般。 火紅的嫁衣襯著肌膚如雪搀继。 梳的紋絲不亂的頭發(fā)上窘面,一...
    開封第一講書人閱讀 51,482評論 1 302
  • 那天,我揣著相機(jī)與錄音叽躯,去河邊找鬼财边。 笑死,一個胖子當(dāng)著我的面吹牛点骑,可吹牛的內(nèi)容都是我干的酣难。 我是一名探鬼主播,決...
    沈念sama閱讀 40,271評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼黑滴,長吁一口氣:“原來是場噩夢啊……” “哼憨募!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起跷跪,我...
    開封第一講書人閱讀 39,166評論 0 276
  • 序言:老撾萬榮一對情侶失蹤馋嗜,失蹤者是張志新(化名)和其女友劉穎齐板,沒想到半個月后吵瞻,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體葛菇,經(jīng)...
    沈念sama閱讀 45,608評論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,814評論 3 336
  • 正文 我和宋清朗相戀三年橡羞,在試婚紗的時候發(fā)現(xiàn)自己被綠了眯停。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,926評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡卿泽,死狀恐怖莺债,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情签夭,我是刑警寧澤齐邦,帶...
    沈念sama閱讀 35,644評論 5 346
  • 正文 年R本政府宣布,位于F島的核電站第租,受9級特大地震影響措拇,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜慎宾,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,249評論 3 329
  • 文/蒙蒙 一丐吓、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧趟据,春花似錦券犁、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,866評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至咳促,卻和暖如春色难,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背等缀。 一陣腳步聲響...
    開封第一講書人閱讀 32,991評論 1 269
  • 我被黑心中介騙來泰國打工枷莉, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人尺迂。 一個月前我還...
    沈念sama閱讀 48,063評論 3 370
  • 正文 我出身青樓笤妙,卻偏偏與公主長得像,于是被迫代替她去往敵國和親噪裕。 傳聞我的和親對象是個殘疾皇子蹲盘,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,871評論 2 354

推薦閱讀更多精彩內(nèi)容