iOS高级

ReactiveCocoa操作方法(过滤,秩序,时间,重复)

2016-05-29  本文已影响267人  CharType

ReactiveCocoa操作方法过滤

filter:过滤信号,可以使用它获取满足调价的信号
//每次信号发出都会先执行过滤条件判断
[[self.textfield1.rac_textSignal filter:^BOOL(NSString *value) {
// 当条件判断等于YES的时候才会调用订阅的block
return value.length>5;
}] subscribeNext:^(id x) {
self.loginBtn.enabled = YES;
} ];
ignore:忽略完某些值的信号
// 内部调用filter过滤,忽略掉ignore的值
[[self.textfield1.rac_textSignal ignore:@"123"] subscribeNext:^(id x) {
NSLog(@"%@",x);
}];

distinctUntilChanged:当上一次的值和这次的值有明显变化的时候就会发出信号,否则会忽略掉
RACSubject *subject = [RACSubject subject];
//当上一次的值和这次的值有明显变化的时候就会发出信号,否则会忽略掉
//一般用来刷新UI界面,当数据有变化的时候才会刷新
[[subject distinctUntilChanged] subscribeNext:^(id x) {
NSLog(@"%@",x);
}];

[subject sendNext:@"123456"];
[subject sendNext:@"12346”];

take:从开始一共取N次的信号
RACSubject *subject = [RACSubject subject];
//只取前两次的信号
[[subject take:2] subscribeNext:^(id x) {
NSLog(@"%@",x);
}];

[subject sendNext:@"123456"];
[subject sendNext:@"12346"];
[subject sendNext:@"123456"];
[subject sendNext:@"12346”];

takeLast:取最后N次的信号,前提条件订阅者必须调用完成,因为只有完成才知道一共有多少信号

RACSubject *subject = [RACSubject subject];
//只取最后两次的信号
[[subject takeLast:2] subscribeNext:^(id x) {
NSLog(@"%@",x);
}];

[subject sendNext:@"123456"];
[subject sendNext:@"12346"];
[subject sendNext:@"last1"];
[subject sendNext:@"last2"];
[subject sendCompleted];//订阅者必须调用完成
//输出
/*
2016-05-18 15:04:36.700 ReactiveCocoaTest1[3220:219323] last1
2016-05-18 15:04:36.701 ReactiveCocoaTest1[3220:219323] last2

*/

skip:(NSUInteger):跳过几个信号,不接受
//感觉这个地方有bug,当文本框获取到焦点的时候就调用了
//因为程序启动初始化这个空间的时候会调用第一次
// 输入第一次不会被监听到,跳过第一次发出的信号
[[self.textfield1.rac_textSignal skip:1] subscribeNext:^(id x) {
NSLog(@"%@",x);
}];

ReactiveCocoa操作方法之秩序
doNext: 执行Next之前,会先执行这个Block
doCompleted:: 执行sendCompleted之前,会先执行这个Block

RACSignal *signal = [[[RACSignal createSignal:^RACDisposable *(id<RACSubscriber> subscriber) {
[subscriber sendNext:@"100"];

    [subscriber sendCompleted];
    NSLog(@"发送完毕");
    return nil;
}] doNext:^(id x) {
    // 执行[subscriber sendNext:@100];之前会调用这个Block
     NSLog(@"doNext%@",x);
}] doCompleted:^{
    //执行[subscriber sendCompleted];之前调用这个block
     NSLog(@"doCompleted");;
}];

[signal subscribeNext:^(id x) {
    NSLog(@"%@",x);
}];
/*
 输出:
 2016-05-18 15:42:53.720 ReactiveCocoaTest1[4966:252147] doNext100
 2016-05-18 15:42:53.720 ReactiveCocoaTest1[4966:252147] 100
 2016-05-18 15:42:53.720 ReactiveCocoaTest1[4966:252147] doCompleted
 2016-05-18 15:42:53.720 ReactiveCocoaTest1[4966:252147] 发送完毕
 */

ReactiveCocoa操作方法之时间
timeout:超时,可以让一个信号在一定的时间后,自动报错。
RACSignal *signal = [[RACSignal createSignal:^RACDisposable *(id<RACSubscriber> subscriber) {
[subscriber sendNext:@"100"];
return nil;
}] timeout:1 onScheduler: [RACScheduler currentScheduler]];

[signal subscribeNext:^(id x) {
    NSLog(@"%@",x);
} error:^(NSError *error) {
    
    NSLog(@"1秒后会自动调用");
}];

interval:定时,每隔一段时间发出信号
//每隔一秒钟就会发出信号
[[RACSignal interval:1 onScheduler:[RACScheduler currentScheduler]] subscribeNext:^(id x) {
NSLog(@"%@",x);
}];

delay:延迟发送Next
[[[RACSignal createSignal:^RACDisposable *(id<RACSubscriber> subscriber) {
[subscriber sendNext:@"100"];

    return nil;
}] delay:2] subscribeNext:^(id x) {
    //调用[subscriber sendNext:@"100"] 2秒之后执行这个block
    NSLog(@"%@",x);
}];

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) {
    
}];
/*
 输出:
 2016-05-18 17:07:27.494 ReactiveCocoaTest1[5695:293689] 接收到错误
 2016-05-18 17:07:27.522 ReactiveCocoaTest1[5695:293689] 接收到错误
 2016-05-18 17:07:27.523 ReactiveCocoaTest1[5695:293689] 接收到错误
 2016-05-18 17:07:27.523 ReactiveCocoaTest1[5695:293689] 接收到错误
 2016-05-18 17:07:27.523 ReactiveCocoaTest1[5695:293689] 接收到错误
 2016-05-18 17:07:27.524 ReactiveCocoaTest1[5695:293689] 接收到错误
 2016-05-18 17:07:27.524 ReactiveCocoaTest1[5695:293689] 接收到错误
 2016-05-18 17:07:27.525 ReactiveCocoaTest1[5695:293689] 接收到错误
 2016-05-18 17:07:27.525 ReactiveCocoaTest1[5695:293689] 接收到错误
 2016-05-18 17:07:27.525 ReactiveCocoaTest1[5695:293689] 接收到错误
 2016-05-18 17:07:27.525 ReactiveCocoaTest1[5695:293689] 1
 */

replay重放,当一个信号被订阅多次,反复播放内容
//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);
}];

[signal sendNext:@"100"];
[signal sendNext:@"1000"];
//输出 2016-05-18 17:14:24.841 ReactiveCocoaTest1[6097:299606] 1000

不正确之处,欢迎补充
测试代码 https://github.com/CharType/ReactiveCocoaTest

上一篇下一篇

猜你喜欢

热点阅读