使用ReactiveCocoa改善工作流程

使用 ReactiveCocoa (下文將用 RAC 簡稱)有一段時間了,寫點東西記錄一下心得境析,權(quán)當(dāng)分享。我的知識大多都是從開源社區(qū)派诬,或者其他人的分享處得來劳淆,知識如果不分享,那將沒有意義默赂。所以我很希望自己的經(jīng)驗也能夠幫助一些新人沛鸵,盡早走出新手村。

為什么要用 RAC ?

優(yōu)點:對個人而言缆八,RAC 能節(jié)省代碼量曲掰,項目的結(jié)構(gòu)更漂亮,邏輯更清晰奈辰。 節(jié)省代碼量 栏妖,就能更專注于其他工作,而不需要書寫一些繁雜的與業(yè)務(wù)邏輯無關(guān)的代碼實現(xiàn)冯挎。節(jié)省代碼量另一種意義上來說就是等于 珍惜生命 。隨著代碼量的減少咙鞍,代碼結(jié)構(gòu)也會變得更清晰房官。

看起來很棒,這東西沒有缺點续滋?當(dāng)然有翰守,如果說人們對某樣?xùn)|西只談優(yōu)點不談缺點,那一定是在耍流氓……

缺點:函數(shù)式編程的思想對新手不友好疲酌,可讀性對新手不友好蜡峰,有一定的學(xué)習(xí)時間成本了袁。

總的來說,好處還是占很大比例湿颅,我不打算講解底層概念载绿,寫得很清楚的大有人在。我只想通過一些簡單的盡可能精簡的小例子拋磚引玉油航,讓新手能快速上手崭庸,直接能看到使用RAC之后的好處,來決定是否使用RAC來改善工作流程谊囚。


安裝RAC

簡述一下安裝步驟
首先利用CocoaPods安裝RAC怕享。

1.安裝CocoaPods,以及配置podfile文件

2.在podfile文件中加入 pod 'ReactiveCocoa', '~> 2.5'(Objective-C版本镰踏,指定2.5版本)函筋。

3.終端執(zhí)行pod update執(zhí)行安裝。


Demo奠伪,項目中的常用方法:

UIButton 事件的點擊

// 生成按鈕
- (void)setupButton{
    UIButton *button = [[UIButton alloc] initWithFrame:CGRectMake(100, 100, 100, 100)];
    [button setTitle:@"按鈕" forState:UIControlStateNormal];
    [self.view addSubview:button];
    [button addTarget:self action:@selector(click) forControlEvents:UIControlEventTouchUpInside];
}

// 點擊事件
- (void)click{
    NSLog(@"按鈕點擊了");
}

可以看到跌帐,這是生成一個按鈕需要的代碼,如果某個按鈕要遷移到另一個頁面芳来,或者現(xiàn)在需要刪除某個按鈕含末,就要找到兩個地方才能刪除干凈,我個人覺得即舌,它很分散佣盒,UI事件分開,界面中只有一兩個按鈕那還算好找顽聂,實際項目中的代碼量會比較多肥惭,找起來非常非常會心累。用RAC怎么實現(xiàn)呢紊搪?嗯蜜葱,這樣:

- (void)setupButton{
    // UI
    UIButton *button = [[UIButton alloc] initWithFrame:CGRectMake(100, 100, 100, 100)];
    [button setTitle:@"按鈕" forState:UIControlStateNormal];
    [self.view addSubview:button];
    // 事件
    [[button rac_signalForControlEvents:UIControlEventTouchUpInside] subscribeNext:^(id x) {
        NSLog(@"按鈕點擊了");
    }];
}

非常酷耀石,UI事件終于聚集在一起了牵囤,復(fù)制或者刪除將會很方便,看到一個按鈕就能緊跟著看到它的實現(xiàn)滞伟,減少了心智負(fù)擔(dān)揭鳞。


UITextField 獲取每一次輸入的數(shù)據(jù)

- (void)setupUITextField{
    // UI
    UITextField *TextField = [[UITextField alloc] initWithFrame:CGRectMake(100, 100, 100, 100)];
    [self.view addSubview:TextField];
    // 事件
    [TextField.rac_textSignal subscribeNext:^(NSString *x) {
        NSLog(@"當(dāng)前輸入框輸入字符為:%@", x);
    }];
}

每次有字符輸入的時候,都會觸發(fā)Block中的內(nèi)容,非常方便就能獲取到數(shù)據(jù)梆奈。


UITableView 監(jiān)聽滾動偏移值

- (void)setupUITextField{
    // UI
    UITableView *tableView = [[UITableView alloc] initWithFrame:CGRectMake(100, 100, 100, 100)];
    [self.view addSubview:tableView];
    // 事件
    [RACObserve(tableView, contentOffset) subscribeNext:^(id x) {
        CGPoint offset = [x CGPointValue];
        NSLog(@"tableView的偏移值發(fā)生改變野崇,偏移值為:x:%f,y:%f", offset.x, offset.y);
    }];
}

免去了寫KVO的繁雜代碼,用RAC來監(jiān)聽TableView的偏移值亩钟,訂閱到的數(shù)據(jù)是對象類型乓梨,要轉(zhuǎn)換為CGPoint結(jié)構(gòu)體才能使用鳖轰。


利用RAC避免回調(diào)地獄

回調(diào)地獄(多層回調(diào)嵌套)是很可怕的事情,假設(shè)我們有一個頁面扶镀,需要依賴三個數(shù)據(jù)蕴侣,三個數(shù)據(jù)同時下載完畢后再刷新頁面。不太好的寫法如下:

- (void)downData{
    
    __block id a, b ,c;
    [self download:^(NSData *data) {
        NSLog(@"數(shù)據(jù)a下載完成");
        a = data;
        [self download:^(NSData *data) {
            NSLog(@"數(shù)據(jù)b下載完成");
            b = data;
            [self download:^(NSData *data) {
                NSLog(@"數(shù)據(jù)c下載完成");
                c = data;
                [self setupView:@[a, b, c]];
            }];
        }];
    }];
    
}

- (void)setupView:(NSArray *)datas{
    NSLog(@"利用abc數(shù)據(jù)刷新頁面");
}

看起來非常多層級狈惫,比較混亂睛蛛,接下來要使用RAC來優(yōu)化代碼,讓層級清晰合理一些胧谈。

- (void)downData {

  __block id a, b, c;
  // 生成三個信號
  RACSubject *signal1 = [RACSubject subject];
  RACSubject *signal2 = [RACSubject subject];
  RACSubject *signal3 = [RACSubject subject];
    // 合并信號忆肾,三個信號都觸發(fā)后,才激活 subscribeNext Block
  [[RACSignal combineLatest:@[ signal1, signal2, signal3 ]
                     reduce:^id {
                       return @"";
                     }] subscribeNext:^(id x) {
    NSLog(@"全部數(shù)據(jù)下載完畢菱肖,刷新UI");
    [self setupView:@[ a, b, c ]];
  }];

  [self download:^(NSData *data) {
    NSLog(@"數(shù)據(jù)a下載完成");
    a = data;
    [signal1 sendNext:nil];
  }];
  [self download:^(NSData *data) {
    NSLog(@"數(shù)據(jù)b下載完成");
    b = data;
    [signal2 sendNext:nil];
  }];
  [self download:^(NSData *data) {
    NSLog(@"數(shù)據(jù)c下載完成");
    c = data;
    [signal3 sendNext:nil];
  }];
}

- (void)setupView:(NSArray *)datas {

  NSLog(@"利用abc數(shù)據(jù)刷新頁面");
}

這樣代碼就清晰多了客冈,以上一些方法都是常用的部分方法,簡單列出自己的使用經(jīng)驗稳强,給新人們做個參考场仲。時間有限,寫得有點匆忙退疫,有什么問題渠缕,請給我評論,或者留言褒繁。我會盡心盡力幫助每一個新人亦鳞。好了,下次再見~

拖延癥一犯棒坏,不知何年何月……

相關(guān)學(xué)習(xí)資料

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末燕差,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子坝冕,更是在濱河造成了極大的恐慌徒探,老刑警劉巖,帶你破解...
    沈念sama閱讀 210,914評論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件喂窟,死亡現(xiàn)場離奇詭異测暗,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)磨澡,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 89,935評論 2 383
  • 文/潘曉璐 我一進(jìn)店門碗啄,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人钱贯,你說我怎么就攤上這事挫掏≌炝恚” “怎么了秩命?”我有些...
    開封第一講書人閱讀 156,531評論 0 345
  • 文/不壞的土叔 我叫張陵尉共,是天一觀的道長。 經(jīng)常有香客問我弃锐,道長袄友,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,309評論 1 282
  • 正文 為了忘掉前任霹菊,我火速辦了婚禮剧蚣,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘旋廷。我一直安慰自己鸠按,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 65,381評論 5 384
  • 文/花漫 我一把揭開白布饶碘。 她就那樣靜靜地躺著目尖,像睡著了一般。 火紅的嫁衣襯著肌膚如雪扎运。 梳的紋絲不亂的頭發(fā)上瑟曲,一...
    開封第一講書人閱讀 49,730評論 1 289
  • 那天,我揣著相機(jī)與錄音豪治,去河邊找鬼洞拨。 笑死,一個胖子當(dāng)著我的面吹牛负拟,可吹牛的內(nèi)容都是我干的烦衣。 我是一名探鬼主播,決...
    沈念sama閱讀 38,882評論 3 404
  • 文/蒼蘭香墨 我猛地睜開眼齿椅,長吁一口氣:“原來是場噩夢啊……” “哼琉挖!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起涣脚,我...
    開封第一講書人閱讀 37,643評論 0 266
  • 序言:老撾萬榮一對情侶失蹤示辈,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后遣蚀,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體矾麻,經(jīng)...
    沈念sama閱讀 44,095評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,448評論 2 325
  • 正文 我和宋清朗相戀三年芭梯,在試婚紗的時候發(fā)現(xiàn)自己被綠了险耀。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 38,566評論 1 339
  • 序言:一個原本活蹦亂跳的男人離奇死亡玖喘,死狀恐怖甩牺,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情累奈,我是刑警寧澤贬派,帶...
    沈念sama閱讀 34,253評論 4 328
  • 正文 年R本政府宣布急但,位于F島的核電站,受9級特大地震影響搞乏,放射性物質(zhì)發(fā)生泄漏波桩。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 39,829評論 3 312
  • 文/蒙蒙 一请敦、第九天 我趴在偏房一處隱蔽的房頂上張望镐躲。 院中可真熱鬧,春花似錦侍筛、人聲如沸萤皂。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,715評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽敌蚜。三九已至,卻和暖如春窝爪,著一層夾襖步出監(jiān)牢的瞬間弛车,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,945評論 1 264
  • 我被黑心中介騙來泰國打工蒲每, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留纷跛,地道東北人。 一個月前我還...
    沈念sama閱讀 46,248評論 2 360
  • 正文 我出身青樓邀杏,卻偏偏與公主長得像贫奠,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子望蜡,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 43,440評論 2 348

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

  • 發(fā)現(xiàn) 關(guān)注 消息 iOS 第三方庫唤崭、插件、知名博客總結(jié) 作者大灰狼的小綿羊哥哥關(guān)注 2017.06.26 09:4...
    肇東周閱讀 12,058評論 4 62
  • 今天閨蜜約我出來,讓我?guī)兔o她的男同學(xué)挑生日禮物小泉。任務(wù)完成后已經(jīng)是中午芦疏,我們坐下來吃頓飯。 閑暇微姊,她談起自己在校園...
    蠢小妖viviwen閱讀 534評論 0 6
  • “喂酸茴!你們的大軍何時來襲?”月歌回頭小聲問兢交,身后的樹叢里默然無聲薪捍。 許久,仆多磕磕巴巴的聲音傳來:“你怎知我們有大...
    十一鸞閱讀 586評論 0 1
  • DAY 6 吵架到底怎么吵与倡? 上星期三余舟跟男朋友鬧矛盾了,到現(xiàn)在已經(jīng)一星期昆稿,持續(xù)冷戰(zhàn)中,每天無精打采息拜,跟我們聊天...
    阿聽_TinkleBell閱讀 711評論 0 2
  • 路過一中十字路口溉潭, 紅燈閃爍的時間似乎特別長。 遠(yuǎn)眺斜對面的高壓線少欺,起重機(jī)喳瓣,構(gòu)成一幅畫。于是赞别,那一刻的等待變得有點...
    嘟嘟熊的玩美時光閱讀 180評論 0 2