(IV) ReactiveCocoa(RAC)编程思想和MVVM架构进阶
9.6 ReactiveCocoa操作方法之过滤。
filter
:过滤信号,使用它可以获取满足条件的信号.// 过滤: // 每次信号发出,会先执行过滤条件判断. [_textField.rac_textSignal filter:^BOOL(NSString *value) { return value.length > 3; }];
ignore
:忽略完某些值的信号.// 内部调用filter过滤,忽略掉ignore的值 [[_textField.rac_textSignal ignore:@"1"] subscribeNext:^(id x) { NSLog(@"%@",x); }];
distinctUntilChanged
:当上一次的值和当前的值有明显的变化就会发出信号,否则会被忽略掉。// 过滤,当上一次和当前的值不一样,就会发出内容。 // 在开发中,刷新UI经常使用,只有两次数据不一样才需要刷新 [[_textField.rac_textSignal distinctUntilChanged] subscribeNext:^(id x) { NSLog(@"%@",x); }];
take
:从开始一共取N次的信号// 1、创建信号 RACSubject *signal = [RACSubject subject]; // 2、处理信号,订阅信号 [[signal take:1] subscribeNext:^(id x) { NSLog(@"%@",x); }]; // 3.发送信号 [signal sendNext:@1]; [signal sendNext:@2];
takeLast
:取最后N次的信号,前提条件,订阅者必须调用完成,因为只有完成,就知道总共有多少信号.// 1、创建信号 RACSubject *signal = [RACSubject subject]; // 2、处理信号,订阅信号 [[signal takeLast:1] subscribeNext:^(id x) { NSLog(@"%@",x); }]; // 3.发送信号 [signal sendNext:@1]; [signal sendNext:@2]; [signal sendCompleted];
takeUntil
:(RACSignal *):获取信号直到执行完这个信号// 监听文本框的改变,知道当前对象被销毁 [_textField.rac_textSignal takeUntil:self.rac_willDeallocSignal];
skip
:(NSUInteger):跳过几个信号,不接受。// 表示输入第一次,不会被监听到,跳过第一次发出的信号 [[_textField.rac_textSignal skip:1] subscribeNext:^(id x) { NSLog(@"%@",x); }];
switchToLatest
:用于signalOfSignals(信号的信号),有时候信号也会发出信号,会在signalOfSignals中,获取signalOfSignals发送的最新信号。RACSubject *signalOfSignals = [RACSubject subject]; RACSubject *signal = [RACSubject subject]; [signalOfSignals sendNext:signal]; [signal sendNext:@1]; // 获取信号中信号最近发出信号,订阅最近发出的信号。 // 注意switchToLatest:只能用于信号中的信号 [signalOfSignals.switchToLatest subscribeNext:^(id x) { NSLog(@"%@",x); }];
9.7 ReactiveCocoa操作方法之秩序。
doNext
: 执行Next之前,会先执行这个BlockdoCompleted
: 执行sendCompleted之前,会先执行这个Block[[[[RACSignal createSignal:^RACDisposable *(id<RACSubscriber> subscriber) { [subscriber sendNext:@1]; [subscriber sendCompleted]; return nil; }] doNext:^(id x) { // 执行[subscriber sendNext:@1];之前会调用这个Block NSLog(@"doNext");; }] doCompleted:^{ // 执行[subscriber sendCompleted];之前会调用这个Block NSLog(@"doCompleted");; }] subscribeNext:^(id x) { NSLog(@"%@",x); }];
- 9.8 ReactiveCocoa操作方法之线程。
deliverOn
: 内容传递切换到制定线程中,副作用在原来线程中,把在创建信号时block中的代码称之为副作用。subscribeOn
: 内容传递和副作用都会切换到制定线程中。
9.9 ReactiveCocoa操作方法之时间。
timeout
:超时,可以让一个信号在一定的时间后,自动报错。RACSignal *signal = [[RACSignal createSignal:^RACDisposable *(id<RACSubscriber> subscriber) { return nil; }] timeout:1 onScheduler:[RACScheduler currentScheduler]]; [signal subscribeNext:^(id x) { NSLog(@"%@",x); } error:^(NSError *error) { // 1秒后会自动调用 NSLog(@"%@",error); }];
interval
定时:每隔一段时间发出信号[[RACSignal interval:1 onScheduler:[RACScheduler currentScheduler]] subscribeNext:^(id x) { NSLog(@"%@",x); }];
delay
延迟发送next。RACSignal *signal = [[[RACSignal createSignal:^RACDisposable *(id<RACSubscriber> subscriber) { [subscriber sendNext:@1]; return nil; }] delay:2] subscribeNext:^(id x) { NSLog(@"%@",x); }];
9.10 ReactiveCocoa操作方法之重复。
retry
重试 :只要失败,就会重新执行创建信号中的block,直到成功.
__block int i = 0;
[[[RACSignal createSignal:^RACDisposable *(id<RACSubscriber> subscriber) {
if (i == 10) {
[subscriber sendNext:@1];
}else{
NSLog(@"接收到错误");
[subscriber sendError:nil];
}
i++;
return nil;
}] retry] subscribeNext:^(id x) {
NSLog(@"%@",x);
} error:^(NSError *error) {
}];
replay
重放:当一个信号被多次订阅,反复播放内容
RACSignal *signal = [[RACSignal createSignal:^RACDisposable *(id<RACSubscriber> subscriber) {
[subscriber sendNext:@1];
[subscriber sendNext:@2];
return nil;
}] replay];
[signal subscribeNext:^(id x) {
NSLog(@"第一个订阅者%@",x);
}];
[signal subscribeNext:^(id x) {
NSLog(@"第二个订阅者%@",x);
}];
throttle
节流:当某个信号发送比较频繁时,可以使用节流,在某一段时间不发送信号内容,过了一段时间获取信号的最新内容发出。
RACSubject *signal = [RACSubject subject];
_signal = signal;
// 节流,在一定时间(1秒)内,不接收任何信号内容,过了这个时间(1秒)获取最后发送的信号内容发出。
[[signal throttle:1] subscribeNext:^(id x) {
NSLog(@"%@",x);
}];