使用cocoaPods在podfile中添加 pod 'ReactiveObjC', '~> 3.1.0'
1. RACSignal框架中最常用的一个类
RACSiganl:信号类,表示将来有数据传递,只要有数据改变,信号内部接收到数据,就会马上发出数据
默认一个信号都是冷信号,也就是值改变了,也不会触发,只有订阅了这个信号,这个信号才会变为热信号,值改变了才会触发。
如何订阅信号:调用信号RACSignal的subscribeNext就能订阅。
创建步骤:
1.创建信号
+(RACSignal *)createSignal:(RACDisposable *(^)(id subscriber))didSubscribe
2.订阅信号,才会激活信号
-(RACDisposable*)subscribeNext:(void(^)(id x))nextBlock
3.发送信号
-(void)sendNext:(id)value
4. //如果要取消就拿到 RACDisposable
//2.订阅信号
RACDisposable *disposable = [signal subscribeNext:^(id x) {
NSLog(@"%@",x);
}];
//取消订阅
[disposable dispose];、
5.// 这里记住一定要调用sendCompleted方法,因为不调用完成这个方法,信号就不会销毁,一直占用着内存,这个是开发者们最不希望看到的
[subscriber sendCompleted];
/**
按钮的点击事件
*/
- (void)addButtonTarget {
UIButton *loginButton = [[UIButton alloc] init];
loginButton.backgroundColor = [UIColor grayColor];
loginButton.frame = CGRectMake(150, 220, 100, 100);
[self.view addSubview:loginButton];
[[loginButton rac_signalForControlEvents:UIControlEventTouchUpInside] subscribeNext:^(__kindof UIControl * _Nullable x) {
NSLog(@"%@", x);
}];
}
// 监听文本框的输入,而且只有大于3个长度的时候才会打印
[[textFidle.rac_textSignal filter:^BOOL(NSString * _Nullable value) {
return value.length > 3;
}]
subscribeNext:^(NSString * _Nullable x) {
NSLog(@"%@", x);
}];
}
时时判断textfiled中的文字长度
[[self.usernameTextField.rac_textSignal
filter:^BOOL(id value) {
NSString *text = value;
return text.length > 3;
}]
subscribeNext:^(id x) {
NSLog(@"%@", x);
}]
可以看到,rac_textSignal是这个事件的源头。之后数据流通过一个过滤器,只允许包含长度超过3的的字符串的事件通过。符合条件的事件最后来到subscribeNext:方法,事件传递的值在block中打印。
1.关于RAC你有怎样运用到解决不同API依赖关系?
信号的依赖
使用场景是当信号A执行完才会执行信号B,和请求的依赖很类似,例如请求A请求完毕才执行请求B,我们需要注意信号A必须要执行发送完成信号,否则信号B无法执行
//这相当于网络请求中的依赖,必须先执行完信号A才会执行信号B
//经常用作一个请求执行完毕后,才会执行另一个请求
//注意信号A必须要执行发送完成信号,否则信号B无法执行
RACSignal * concatSignal = [self.signalA concat:self.signalB]
//这里我们是对这个拼接信号进行订阅
[concatSignal subscribeNext:^(id x) {
NSLog(@"%@",x);
}];</pre>
2.ReactiveCocoa的热信号与冷信号?