MVVM与ReactiveCocoa

MVVM是一种编程思想 ,它的目标就是为了简化Model层的Controller层,如果有必要viewModel层不可以添加多个,viewModel就是信息的中转中,它负责着数据的获取和分发,相比较而言,MVVM比MVC有更明确的任务划分,MVVM中VM就只负责数据请求,逻辑处理,V(控制器和View,在MVVM中将ViewController视作View)就只负责页面展示和UI交互。

MVVM虽然有更明确的分工,但这样的分工必然带来复杂的数据通信问题,MV获取到数据要将数据传到V中去显示,V中的一个事件要让VM中做数据请求处理操作,其中涉及到了上到下的数据通信,下到上的数据通信,也有可能是跨多层级间的数据通信,还有不同线程间的数据通信,我们知道这些数据通信我们都可以通过代理,通知,block来解决,但会使可能会程序设计变得复杂而零乱,让人想要放弃MVVM。有了响应式编程之后,不同层级之间的通信变得简单,一个信号可以传递事件还可以携带我们想要传递的数据,大大提高了编程效率,MVVM和响应式编程是一个黄金搭档。

一个完整的信号由等待执行的代码块和代码块执行完成后返回的值组成,当一个信号管理者触发了信号,信号会执行代码块,并把结果返回。这两部分缺一不可。一个没有等待执行的代码块或者是没有监测者的信号是没有意义的,这样的信号都不会被触发。

[信号 filter:^BOOL(id value){return 判断结果]生成一个新的信号;

filter操作:对信号返回的值进行过滤,只有判断结果满足的情况下,新信号的subscribeNext方法才会返回值;

[信号 map:^BOOL(id value){return 返回新值]生成一个返回新值的新信号;

map操作:对信号返回的值进行加工处理,新信号的subscribeNext方法将会返回这个新的值;

[信号 flattenMap:^id(id x){return 返回一个信号]生成一个返回信号的新信号,同时还从内部信号发送事件到外部信号

flattenMap操作:将信号返回的值转换成内部信号,同时还将内部信号返回的值转作为该信号的返回值,新信号的subscribeNext方法将会直接返回这个内部信号的返回值;

[信号 doNext:^(id x){附加操作}]当信号返回值的时候做一些附加操作(按钮状态更新,返回数据存储),附加操作并不改变事件本身;

[信号combineLatest:@[信号1,信号2]

reduce:^id(信号1返回值,信号2返回值){

return返回新值;

}];生成一个返回新值的新信号;

combineLatest操作:对多个信号返回的值进行加工处理合并生,成一个新的返回值,新信号的subscribeNext方法将会返回这个新的值;

[RACSignal createSignal:^RACDisposable *(id subscriber){return订阅被取消时执行一些清理工作}];方法创建了一个信号,当这个信号有subscriber时,block里的代码就会执行,你可以发送任意数量的next事件,或者用error\complete事件来终止。

subscription=[信号subscribeNext];所有RACSignal的订阅方法都会返回一个RACDisposable实例,它允许你通过处置方法手动的移除订阅,[subscription dispose]

@weakify 宏定义允许你创建一个弱引用的影子变量,@strongify宏定义允许你创建一个前面使用@weakify传递的强引用变量。

concat:按一定顺序拼接信号,当多个信号发出的时候,有顺序的接收信号。第一个信号必须发送完成,第二个信号才会被激活

then一个信号订阅执行后,error\complete都会终止,通过then方法可以让信号接收到error时会一直等待不终止,直到completed事件发出,然后订阅者通过自己的block参数返回,这有效地将控制从一个信号传递给下一个。

then用于连接两个信号,当第一个信号完成,才会连接then返回的信号,注意使用then,之前信号的值会被忽略掉,1、先过滤掉之前的信号发出的值。2.使用concat连接then返回的信号;只能接收到第二个信号的值,也就是then返回信号的值.

RACSubject信号中的信号

RACSubject使用步骤

1.创建信号 [RACSubject subject],跟RACSiganl不一样,创建信号时没有block。

2.订阅信号 - (RACDisposable *)subscribeNext:(void (^)(id x))nextBlock

3.发送信号 sendNext:(id)value

RACSubject:底层实现和RACSignal不一样。

1.调用subscribeNext订阅信号,只是把订阅者保存起来,并且订阅者的nextBlock已经赋值了。

2.调用sendNext发送信号,遍历刚刚保存的所有订阅者,一个一个调用订阅者的nextBlock。

RACSignal,RACSubject,RACCommand的区别:

RACSignal:一般用来传递简单的信号(按钮,textView等已经集成好的信号),而本身不能够完成发送,需要借助UI事情或RACCommand才能完成信号的发送;

RACSubject(单工):当我们只单向传递一个信号,并且信号中要传递一个自定的对象时,创建RACSubject,自身可以完成发送;注,我们在使用RACSubject时,RACSubject是一个热信号,当它的订阅者被销毁时并不会自动取消订阅,当我们重新发送信号时,信号依然会发送跟之前的订阅者,所以再我们不需要订阅信号的时候,需要我们手动发送sendCommand来取消订阅,否则会出现重复收到信号的情况。

RACCommand(半双工):当我们需要一个信号能够双向传值,即开始发从信号时传入一个对象,信号订阅者处理完信号后又返回一个对象;RACCommand的功能强大可以完成RACSignal,和RACSubject的功能,在项目中我们的很多信号都是通过按钮点击来发送的,RACSignalt和RACCommand都可以和按钮点击事件关联,所以当按钮点击发送信号时,即使是单向传递一个信号,也一般会选用RACSignal或RACCommand,只有当信号的发送由控制器的生命周期,代理事件来触发时,且是单向传递才考虑使用RACSubject;

你可能感兴趣的:(MVVM与ReactiveCocoa)