前言
话说小编第一次接触RAC,内心一万只草泥马奔腾而过,这尼玛的学习曲线直线上升,这也忒陡峭了,不过还是要从心理上克服这种障碍,小编本人在ios进阶的这条道路上已经走了很久了,可千万不能放弃啊!
先来上demo链接https://github.com/muyang00/YERACDemo.git
少年淡定别再紧张
一盏灯, 一片昏黄; 一简书, 一杯淡茶。 守着那一份淡定, 品读属于自己的寂寞。 保持淡定, 才能欣赏到最美丽的风景! 保持淡定, 人生从此不再寂寞。
话说要讲讲RACCommand
RACCommand:RAC中用于处理事件的类,可以把事件如何处理,事件中的数据如何传递,包装到这个类中,他可以很方便的监控事件的执行过程,比如看事件有没有执行完毕
使用场景:监听按钮点击,网络请求
一、 普通做法
RACCommand: 处理事件, 不能返回空的信号
1.创建命令
RACCommand *command = [[RACCommand alloc] initWithSignalBlock:^RACSignal *(id input) {
//block调用,执行命令的时候就会调用
NSLog(@" --- %@",input); // input 为执行命令传进来的参数
// 这里的返回值不允许为nil
return [RACSignal createSignal:^RACDisposable *(id<RACSubscriber> subscriber) {
[subscriber sendNext:@"执行命令产生的数据"];
注意:数据传递完,最好调用sendCompleted,这时命令才执行完毕
[subscriber sendCompleted];
return nil;
}];
}];
```
#### 2. ** 强引用命令,不然会自动销毁,接受不到数据**
_command = command;
####3.执行命令
直接订阅执行命令返回的信号
RACSignal *signal =[command execute:@2]; // 这里其实用到的是replaySubject 可以先发送命令再订阅
// 在这里就可以订阅信号了
[signal subscribeNext:^(id x) {
NSLog(@" ++++ %@",x);
}];
##### 注意事项
1、signalBlock必须要返回一个signal,不能返回nil,
2、如果不想要传递信号,直接创建空的信号返回[RACSignal empty];
3、RACCommand,如果数据传递完毕,必须调用[subscriber sendCompleted],这时命令才会执行完毕,否则永远处于执行中.
4、RACComand需要被强引用,否则接手不到RACCommand中的信号,因此,RACCommand中的信号是延迟发送的。
#####设计思想 : 内部signalBlock为什么要返回一直信号,这个信号有什么用
1、在RAC开发中,通常会把网络请求封装到RACCommand,直接执行某个RACCommand就能发送请求。
2、当RACCommand内部请求到数据的时候,需要把请求的数据传递给外界,这时候就需要通过signalBlock返回的信号传递了
## 二、一般做法
#### 1.创建命令
RACCommand *command = [[RACCommand alloc] initWithSignalBlock:^RACSignal *(id input) {
//block调用,执行命令的时候就会调用
NSLog(@"%@",input); // input 为执行命令传进来的参数
// 这里的返回值不允许为nil
return [RACSignal createSignal:^RACDisposable *(id<RACSubscriber> subscriber) {
[subscriber sendNext:@"执行命令产生的数据"];
注意:数据传递完,最好调用sendCompleted,这时命令才执行完毕
[subscriber sendCompleted];
return nil;
}];
}];
```
2. ** 强引用命令,不然会自动销毁,接受不到数据**
_command = command;
注意:这里必须是先订阅才能发送命令
executionSignals:信号源,信号中信号,signalofsignals:信号,发送数据就是信号
[command.executionSignals subscribeNext:^(RACSignal *x) {
[x subscribeNext:^(id x) {
NSLog(@"%@", x);
}];
// NSLog(@"%@", x);
}];
[command execute:@2];
三、 高阶函数方法
1. 创建命令
同上
2. 执行函数
// switchToLatest获取最新发送的信号,只能用于信号中信号。
// switchToLatest:用于signal of signals,获取signal of signals 发出的最新的信号,也就是可以直接拿到RACCommand中的信号
[command.executionSignals.switchToLatest subscribeNext:^(id x) {
NSLog(@"%@", x);
}];
// 2.执行命令
[command execute:@"擦擦"];
四、 创建信号中信号
RACSubject *signalofsignals = [RACSubject subject];
RACSubject *signalA = [RACSubject subject];
// switchToLatest: 获取信号中信号发送的最新信号
[signalofsignals.switchToLatest subscribeNext:^(id x) {
NSLog(@"%@", x);
}];
// 发送信号
[signalofsignals sendNext:signalA];
[signalA sendNext:@4];
等价于switchToLatest获取信号中信号发送的最新信号
订阅信号
[signalofsignals subscribeNext:^(RACSignal *x) {
[x subscribeNext:^(id x) {
NSLog(@"%@", x);
}];
}];
五、 监听事件
1.创建命令
同上
2. 执行函数
注意:当前命令内部发送数据完成,一定要主动发送完成
[command.executing subscribeNext:^(id x) {
if ([x boolValue] == YES) { // 正在执行
NSLog(@"当前正在执行%@", x);
}else {
// 执行完成/没有执行
NSLog(@"执行完成/没有执行");
}
}];
// 2.执行命令
[command execute:@1];