ReactiveObjc初探

一. 存在的问题

  1. UI更新必须依赖程序员在指定位置手动触发。UI更新的逻辑会遍布各地难以维护,而且调用者必须明确的知道更新的逻辑,因为updatA,updateB,先调后调有时也会发生截然不同的效果。

  2. 举个🌰,假如有一个类似网易云音乐的列表页。歌曲列表请求成功后,赋值tabelView的数据源。注意,此时我们还有执行[tableView reloadData],此外,可能还需要调更新歌曲数,更新专辑封面等等。只要和这个数据源有关的UI元素,我们都需要手动触发一遍。更重要的是要更新哪些UI,需要我们自己判断,极容易引发bug。上述是网络请求的,在类似的多交互页面中,常常还包括侧滑删除、批量增加、名称修改等等对数据源的操作,而这些都意味着我们需要手动触发UI更新。当然,有些共同的更新,我们可以抽成一个方法,但还是难以从根本上避免伴随着用户事件及数据改变的,散落各地的UI更新逻辑。

二. RAC的解决方案

  1. 还是上面那个场景,使用RAC后,只需要关心数据源如果变化,无需关心数据源变化后所引发的UI层面的连锁反应。加载更多,往数据源中加对应数据;删除某首歌,删除数据源中的对应数据。修改数据后,订阅(subscribe)了数据源的相关元素会自动接收到数据变化的信号,并作出对应改变。

  2. 光是上述效果我们用KVO也能做到,RAC更独特的地方在于用信号量(Signal)统一了所有变化,包括网络回调、KVO、通知、block等等,抽象成信号量后,我们可以统一进行逻辑操作,包括combine、filter、map等等,这些操作才是强力的工具。整个流程为事件流->信号流->逻辑操作->订阅。

三. 适合使用RAC的场景举例

  1. 登录注册:登录注册常见的需求有必须同时满足xxx条件,按钮才能启用。

@weakify(self);

    //自动响应登录按钮是否可用

    RAC(self.loginButton, enabled) = [RACSignal

                          combineLatest:@[self.accountTextField.rac_textSignal,

                                          self.pwdTextField.rac_textSignal]

                           reduce:^(NSString *userName,NSString *pwd){

                            return @(userName.length > 0 && pwd.length > 0);

                             }];

    //account属性自动响应更新值

    [[self.accountTextField.rac_textSignal filter:^BOOL(NSString * _Nullable value) {

        return value.length > 0;

    }] subscribeNext:^(NSString * _Nullable x) {

        @strongify(self);

        self.loginViewModel.account = x;

    }];

    //password属性自动响应更新值

    [[self.pwdTextField.rac_textSignal filter:^BOOL(NSString * _Nullable value) {

        return value.length > 0;

    }] subscribeNext:^(NSString * _Nullable x) {

        @strongify(self);

        self.loginViewModel.password = x;

    }];

    //按钮点击事件转成信号流,调用VM中的方法执行。

    [[self.loginButton rac_signalForControlEvents:UIControlEventTouchUpInside] subscribeNext:^(__kindof UIControl * _Nullable x) {

        @strongify(self);

        [[self.loginViewModel.loginCommand executing] subscribeNext:^(id  _Nullable x) {

            NSLog(@"登录成功");

        }];

        [[self.loginViewModel.loginCommand execute:nil] subscribeError:^(NSError * _Nullable error) {

            NSLog(@"登录失败");

        }];

    }];



vm.m

- (void)setupCommand{ 
          @weakify(self); 
        _loginCommand = [[RACCommand alloc] initWithSignalBlock:^RACSignal *                        _Nonnull(id _Nullable input) {
         return [RACSignal createSignal:^RACDisposable * _Nullable(id _Nonnull subscriber) {

            @strongify(self);

            [self loginWithUserName:self.account password:self.password done:^(NSDictionary *result) {

                NSString *userId = [result objectForKey:@"user_id"];

                if (userId) {
                    [subscriber sendCompleted];
                }else{
                    [subscriber sendError:nil];
                }
            }];
            return nil;
        }];
    }];
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 219,539评论 6 508
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 93,594评论 3 396
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 165,871评论 0 356
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,963评论 1 295
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,984评论 6 393
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,763评论 1 307
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,468评论 3 420
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,357评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,850评论 1 317
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 38,002评论 3 338
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 40,144评论 1 351
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,823评论 5 346
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,483评论 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 32,026评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,150评论 1 272
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,415评论 3 373
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 45,092评论 2 355

推荐阅读更多精彩内容