冷信号,可以自己发送消息,但是需要订阅者订阅上一篇文章我们讲到,传统的MVC设计模式Controller将View跟Model进行了绑定,导致不仅要处理业务逻辑,还是需要观察Model的变化通知View,观察View产生的变化告诉Model,耦合性非常的高,牵一发而动全身,如果要在多个页面进行管理,复用性显得不是很理想,那么在进行开发的时候,如何进行模块之前的通信呢,简单来说可以用到ReactiveCocoa框架,它是GitHub评分以及目前比较主流的一种信号框架,将iOS中的代理信号,KVO信号,UI信号,通知等都可以作为信号来处理。总之来说对象面向对象来说,万物皆对象,对于Reactive来说,所有的通信都是信号。
RACSignal
//1、创建信号
RACSignal*signal = [RACSignal createSignal:^RACDisposable * _Nullable(id<RACSubscriber> _Nonnull subscriber) { [subscribersendCompleted]; //处理的事情完毕后执行 }];
2、订阅者订阅消息
[signal subscribeCompleted:^{ //处理接收到信号的响应 }];
热信号,可以自己发送消息,可以自己接收消息
RACSubject
1、创建信号并且订阅
RACSubject *subject = [RACSubject subject]; [subject subscribeNext:^(id _Nullable x) { }];
2、发送信号
[subject sendNext:<#(nullable id)#>];
RAC具体的四种作用,本人只是用RAC时间有限,目前了解到的是以下四种方式
1.代替代理 主要通过RACSubject
代理信号
-(RACSubject*)btnClickSingal{if(_btnClickSingal==nil){_btnClickSingal=[RACSubject subject];}return_btnClickSingal;}
-(IBAction)btnClick:(id)sender{//NSLog(@"红色view监听到按钮点击");//发送信号[self.btnClickSingal sendNext:@"按钮被点击了"];}
代理方
[testView.btnClickSingal subscribeNext:^(id x){NSLog(@"%@",x);}
2.KVO 信号
aView = 需要观察的对象
[aView rac_observeKeyPath:@"frame"options:NSKeyValueObservingOptionNew observer:nil block:^(id value,NSDictionary*change,BOOL causedByDealloc,BOOL affectedOnlyLastComponent){//}];
bView = 需要观察改变后的对象
[[bView rac_valuesForKeyPath:@"frame" observer:nil] subscribeNext:^(id x) { //x 修改的值 NSRect NSLog(@"%@",x); }];
3.UI信号
[[_btn rac_signalForControlEvents:UIControlEventTouchUpInside]subscribeNext:^(id x){NSLog(@"点击了按钮");NSLog(@"%@",x);}];
4.通知信号
[[[NSNotificationCenter defaultCenter]rac_addObserverForName:UIKeyboardWillShowNotification object:nil]subscribeNext:^(id x){NSLog(@"%@",x);}];
冷信号,可以自己发送消息,但是需要订阅者订阅,发送者与订阅者是一对一的关系
RACSignal
//1、创建信号
RACSignal*signal = [RACSignal createSignal:^RACDisposable * _Nullable(id<RACSubscriber> _Nonnull subscriber) { [subscribersendCompleted]; //处理的事情完毕后执行 }];
2、订阅者订阅消息
[signal subscribeCompleted:^{ //处理接收到信号的响应 }];
热信号,可以自己发送消息,可以自己接收消息,发送者与订阅者为一对多的关系
RACSubject
1、创建信号并且订阅
RACSubject *subject = [RACSubject subject]; [subject subscribeNext:^(id _Nullable x) { }];
2、发送信号
[subject sendNext:<#(nullable id)#>];
本文主要讲一下MVVM中,View如何跟View Model进行通信,View Model如何感知Controller发生的变化通知Model,Reactive Cocoa是一种进行异步通知的组件,通过该组件可以很理想的实现View Model为MVC中的Controller进行接耦合,通过发送(信号量),类似于iOS中KVO机制,KeyValueObserver
首先要在合适的场景中,进行事件的响应以及在合适的场景中进行事件的传递,我们需要使用Reactive的sendNext方式,进行方法的传递,在需要接受信号的地方进行subScribie进行信号的接收,
比如说有一个场景,用户点击了单元格的某一行数据,因为View是跟View Model绑定在一起的,TableView无法获取到View的状态,那么如何进行事件的响应呢,答案是通过在Table View注册信号量,通过RACObject的subScrible方法,达到了时间的监听以及响应,A模块不用知道B模块的实例,甚至不需要引用B模块的视图。
比如在传统的MVC中,Controller承担了业务逻辑的处理,用户交互的逻辑处理,模型发生变化告知View的处理,这样让Controller的耦合程度相当之高,在后期需要添加功能进行迭代的时候,需要考虑模块于模块之间的兼容性,以及对于新需求的编写位置,稍有不慎就会造成各种各样的问题,所以就有了MVVM的诞生,初学者可能不太理解什么是MVVM,甚至对于写惯了MVC的开发人员,很难适应新的设计模式,那么如何才能让初学者尽快的去适应这种差异化呢,答案也不是很复杂,将MVVM中View Model,相信成MVC中的Controller,除了不能直接进行页面之间的跳转,其他的基本一致。
如何快速的去实现一个MVVM的模块呢,首先需要创建一个Model文件,继承自NSObject,然后创建一个View文件继承自UIView,最后创建一个View Model,将View与Model引入,绑定View以及Model,通过RAC进行信号的注册信息,添加订阅者订阅消息后进行通信。这样View Model起到观察者的模式,进行View跟Model的通信了,当需要网络请求的时候,View Model替代了Controller网络请求,在需要进行网络请求的时候,View Model进行网络请求,拿到数据后,发送消息信号,Controller成为View Model的订阅者通过注册View Model的订阅消息,而进行View Model的刷新,当然根据业务情况,特殊情况特殊对待,View Model也是自己去刷新。