1.导入ReactiveCocoa
platform :ios, '8.0'
target "ReactiveCocoaLearnDemo" do
use_frameworks!
pod 'ReactiveCocoa','~> 4.2.1'
end
2.学习ReactiveCocoa常见类
在RAC中最核心的类是RACSiganl
RACSiganl:信号类,一般表示将来有数据传递,只要有数据变化,信号内部接收到数据就会马上发出数据.
tips:
1.RACSiganl只是当数据改变时,信号内部会发出数据,它本事不具备发送信号的能力,而是交给内部一个订阅者去发出.
2.默认一个信号都是冷信号,也就是值改变了,也不会触发,只有订阅了这个信号(调用信号RACSiganl的subscribeNext就能订阅),这个信号才会变成热信号,值改变了才会触发.
RACSiganl的简单使用:
RACSiganl的使用步骤:
1.创建信号+(RACSignal *)createSignal:(RACDisposable * (^)(idsubscriber))didSubscribe
2.订阅信号,才会激活信号 - (RACDisposable *)subscribeNext:(void (^)(id x))nextBlock
3.发送信号 - (void)sendNext:(id)value
// RACSignal底层实现:
// 1.创建信号,首先把didSubscribe保存到信号中,还不会触发。
// 2.当信号被订阅,也就是调用signal的subscribeNext:nextBlock
// 2.2 subscribeNext内部会创建订阅者subscriber,并且把nextBlock保存到subscriber中。
// 2.1 subscribeNext内部会调用siganl的didSubscribe
// 3.siganl的didSubscribe中调用[subscriber sendNext:@1];
// 3.1 sendNext底层其实就是执行subscriber的nextBlock
// 1.创建信号 RACSignal *siganl = [RACSignal createSignal:^RACDisposable *(idsubscriber) {
// block调用时刻:每当有订阅者订阅信号,就会调用block。
// 2.发送信号
[subscriber sendNext:@1];
// 如果不在发送数据,最好发送信号完成,内部会自动调用[RACDisposable disposable]取消订阅信号。
[subscriber sendCompleted];
return [RACDisposable disposableWithBlock:^{
// block调用时刻:当信号发送完成或者发送错误,就会自动执行这个block,取消订阅信号。
// 执行完Block后,当前信号就不在被订阅了。
NSLog(@"信号被销毁");
}];
}];
// 3.订阅信号,才会激活信号.
[siganl subscribeNext:^(id x) {
// block调用时刻:每当有信号发出数据,就会调用block.
NSLog(@"接收到数据:%@",x);
}];
RACSubscriber:表示订阅者的意思,用于发送信号,这是一个协议,不是一个类,只要遵守这个协议,并且实现方法才能成为订阅者.通过create创建的信号,都有一个订阅者,帮助它发送数据.
RACDisposable:用于取消订阅或者清理资源,当信号发送完成或者发送错误的时候,就会自动触发他.(如:不想监听某个信号的时候,可以通过它主动取消订阅信号)
RACSubject: 信号的提供者,自己可以充当信号,又能发送信号(通常用来代替代理,有了它就没必要定义代理了)
RACReplaySubject: 重复提供信号的类,RAVSubject的子类.
RACReplaySubject与RACSubject区别:RACReplaySubject可以先发送信号,再订阅信号,RACSubject就不可以(如果一个信号每被订阅一次,就需要把之前的值重复发送一遍,使用RACReplaySubject. 可以设置capacity数量来限制缓存的value的数量,即只缓充最新的几个值)
RACReplaySubject与RACSubject的简单使用:
RACSubject的使用步骤:
1.创建信号 [RACSubject subject],跟RACSiganl 不一样,创建信号时没有block
2.订阅信号 - (RACDisposable *)subscribeNext:(void (^)(id x))nextBlock
3.发送信号 sendNext:(id)value
RACSubject的底层实现和RACSignal不一样
1.调用subjectNext订阅信号,只是把订阅者保存起来,并且订阅者的nextBlock已经赋值了
2.调用sendNext发送信号,遍历刚刚保存的所有订阅者,一个一个调用订阅者的nextBlock.
RACReplaySubject的使用步骤:
1.创建信号 [RACReplaySubject subject],跟RACSiganl不一样,创建信号时没有block.
2.可以先订阅信号,也可以先发送信号
2.1订阅信号 - (RACDisposable *)subscribeNext:(void (^)(id x))nextBlock
2.2发送信号 sendNext:(id)value
RACReplaySubject:底层实现和RACSubject不一样:
1.调用sendNext发送信号,把值保存起来,然后遍历刚刚保存的所有订阅者,一个一个调用订阅者的next
2.调用subscribeNext 订阅信号,遍历保存所有的值,一个一个调用订阅者的nextBlock
如果想当一个信号被订阅 ,就重复播放之前的所有值,需要先发送信号,再订阅信号
RACTuple: 元组类,类似数组,用来包装值
RACSequence:RAC中的集合类,用来替代NSArray ,NSDictionary,可以用它来快速遍历数组和字典
RACCommand : RAC中用于处理事件的类,可以把事件如果处理,事件中的数据如何传递,包含该到这个类中,可以很方便的监控事件的执行过程
RACMulticastConnection : 用于当一个信号.被多次订阅时,为了保证创建信号时,避免多次调用创建信号中的block,造成副作用,可以使用这个类处理(通过RACSignal的-publish或者-muticast:方法创建.)
RACScheduler:RAC中的队列,用GCD封装的
RACUnit : 表示stream不包含有意义的值,看到可以理解为nil
RACEvent: 把数据包装成信号事件(signal event)。它主要通过RACSignal的-materialize来使用
ReactiveCocoa开发中常见用法
rac_signalForSelector:用于替代代理
rac_valuesAndChangesForKeyPath:用于监听某个对象的属性改变
rac_signalForControlEvents:用于监听某个事件
rac_addObserverForName:用于监听某个通知
rac_textSignal:只要文本框发出改变就会发出这个信号
处理当界面有多次请求时,需要都获取到数据时,才能展示界面
rac_liftSelector:withSignalsFromArray:Signals:当传入的Signals(信号数组),每一个signal都至少sendNext过一次,就会去触发第一个selector参数的方法。
使用注意:几个信号,参数一的方法就几个参数,每个参数对应信号发出的数据
网友评论