博客
关于我
RACCommand使用
阅读量:109 次
发布时间:2019-02-25

本文共 4491 字,大约阅读时间需要 14 分钟。

1.RACCommand:RAC中用于处理事件的类,可以把事件如何处理,事件中的数据如何传递,包装到这个类中,他可以很方便的监控事件的执行过程。

2.使用场景:监听按钮点击,网络请求

 

RACCommand的简单使用

 

     一、RACCommand使用步骤:

     1.创建命令 initWithSignalBlock:(RACSignal * (^)(id input))signalBlock

     2.在signalBlock中,创建RACSignal,并且作为signalBlock的返回值

     3.执行命令 - (RACSignal *)execute:(id)input

    

     二、RACCommand使用注意:

     1.signalBlock必须要返回一个信号,不能传nil.

     2.如果不想要传递信号,直接创建空的信号[RACSignal empty];

     3.RACCommand中信号如果数据传递完,必须调用[subscriber sendCompleted],这时命令才会执行完毕,否则永远处于执行中。

     4.RACCommand需要被强引用,否则接收不到RACCommand中的信号,因此RACCommand中的信号是延迟发送的。

    

     三、RACCommand设计思想:内部signalBlock为什么要返回一个信号,这个信号有什么用。

     1.在RAC开发中,通常会把网络请求封装到RACCommand,直接执行某个RACCommand就能发送请求。

     2.当RACCommand内部请求到数据的时候,需要把请求的数据传递给外界,这时候就需要通过signalBlock返回的信号传递了。

    

     四、如何拿到RACCommand中返回信号发出的数据。

     1.RACCommand有个执行信号源executionSignals,这个是signal of signals(信号的信号),意思是信号发出的数据是信号,不是普通的类型。

     2.订阅executionSignals就能拿到RACCommand中返回的信号,然后订阅signalBlock返回的信号,就能获取发出的值。

    

     五、监听当前命令是否正在执行executing

    

     六、使用场景,监听按钮点击,网络请求

// 普通做法- (void)test1 {    // RACCommand: 处理事件    // 不能返回空的信号    // 1.创建命令    RACCommand *command = [[RACCommand alloc] initWithSignalBlock:^RACSignal *(id input) {        //block调用,执行命令的时候就会调用        NSLog(@"%@",input); // input 为执行命令传进来的参数        // 这里的返回值不允许为nil        return [RACSignal createSignal:^RACDisposable *(id
subscriber) { [subscriber sendNext:@"执行命令产生的数据"]; return nil; }]; }]; // 如何拿到执行命令中产生的数据呢? // 订阅命令内部的信号 // ** 方式一:直接订阅执行命令返回的信号 // 2.执行命令 RACSignal *signal =[command execute:@2]; // 这里其实用到的是replaySubject 可以先发送命令再订阅 // 在这里就可以订阅信号了 [signal subscribeNext:^(id x) { NSLog(@"%@",x); }]; }// 一般做法- (void)test2 { // 1.创建命令 RACCommand *command = [[RACCommand alloc] initWithSignalBlock:^RACSignal *(id input) { //block调用,执行命令的时候就会调用 NSLog(@"%@",input); // input 为执行命令传进来的参数 // 这里的返回值不允许为nil return [RACSignal createSignal:^RACDisposable *(id
subscriber) { [subscriber sendNext:@"执行命令产生的数据"]; return nil; }]; }]; // 方式二: // 订阅信号 // 注意:这里必须是先订阅才能发送命令 // executionSignals:信号源,信号中信号,signalofsignals:信号,发送数据就是信号 [command.executionSignals subscribeNext:^(RACSignal *x) { [x subscribeNext:^(id x) { NSLog(@"%@", x); }];// NSLog(@"%@", x); }]; // 2.执行命令 [command execute:@2];}// 高级做法- (void)test3 { // 1.创建命令 RACCommand *command = [[RACCommand alloc] initWithSignalBlock:^RACSignal *(id input) { // block调用:执行命令的时候就会调用 NSLog(@"%@", input); // 这里的返回值不允许为nil return [RACSignal createSignal:^RACDisposable *(id
subscriber) { [subscriber sendNext:@"发送信号"]; return nil; }]; }]; // 方式三 // switchToLatest获取最新发送的信号,只能用于信号中信号。 [command.executionSignals.switchToLatest subscribeNext:^(id x) { NSLog(@"%@", x); }]; // 2.执行命令 [command execute:@3]; } // switchToLatest- (void)test4 { // 创建信号中信号 RACSubject *signalofsignals = [RACSubject subject]; RACSubject *signalA = [RACSubject subject]; // 订阅信号// [signalofsignals subscribeNext:^(RACSignal *x) {// [x subscribeNext:^(id x) {// NSLog(@"%@", x);// }];// }]; // switchToLatest: 获取信号中信号发送的最新信号 [signalofsignals.switchToLatest subscribeNext:^(id x) { NSLog(@"%@", x); }]; // 发送信号 [signalofsignals sendNext:signalA]; [signalA sendNext:@4];} /* RACCommand 通常用来表示某个Action的执行,比如点击Button。它有几个比较重要的属性:executionSignals / errors / executing。 1、executionSignals是signal of signals,如果直接subscribe的话会得到一个signal,而不是我们想要的value,所以一般会配合switchToLatest。 2、errors。跟正常的signal不一样,RACCommand的错误不是通过sendError来实现的,而是通过errors属性传递出来的。 3、executing表示该command当前是否正在执行。 */ // 监听事件有没有完成- (void)test5 { //注意:当前命令内部发送数据完成,一定要主动发送完成 // 1.创建命令 RACCommand *command = [[RACCommand alloc] initWithSignalBlock:^RACSignal *(id input) { // block调用:执行命令的时候就会调用 NSLog(@"%@", input); // 这里的返回值不允许为nil return [RACSignal createSignal:^RACDisposable *(id
subscriber) { // 发送数据 [subscriber sendNext:@"执行命令产生的数据"]; // *** 发送完成 ** [subscriber sendCompleted]; return nil; }]; }]; // 监听事件有没有完成 [command.executing subscribeNext:^(id x) { if ([x boolValue] == YES) { // 正在执行 NSLog(@"当前正在执行%@", x); }else { // 执行完成/没有执行 NSLog(@"执行完成/没有执行"); } }]; // 2.执行命令 [command execute:@1]; }

 

转载地址:http://skr.baihongyu.com/

你可能感兴趣的文章
MySQL in 太多过慢的 3 种解决方案
查看>>
MySQL InnoDB 三大文件日志,看完秒懂
查看>>
Mysql InnoDB 数据更新导致锁表
查看>>
Mysql Innodb 锁机制
查看>>
MySQL InnoDB中意向锁的作用及原理探
查看>>
MySQL InnoDB事务隔离级别与锁机制深入解析
查看>>
Mysql InnoDB存储引擎 —— 数据页
查看>>
Mysql InnoDB存储引擎中的checkpoint技术
查看>>
Mysql InnoDB存储引擎中缓冲池Buffer Pool、Redo Log、Bin Log、Undo Log、Channge Buffer
查看>>
MySQL InnoDB引擎的锁机制详解
查看>>
Mysql INNODB引擎行锁的3种算法 Record Lock Next-Key Lock Grap Lock
查看>>
mysql InnoDB数据存储引擎 的B+树索引原理
查看>>
mysql innodb通过使用mvcc来实现可重复读
查看>>
mysql insert update 同时执行_MySQL进阶三板斧(三)看清“触发器 (Trigger)”的真实面目...
查看>>
mysql interval显示条件值_MySQL INTERVAL关键字可以使用哪些不同的单位值?
查看>>
Mysql join原理
查看>>
MySQL Join算法与调优白皮书(二)
查看>>
Mysql order by与limit混用陷阱
查看>>
Mysql order by与limit混用陷阱
查看>>
mysql order by多个字段排序
查看>>