第一天ReactiveCocoa的学习

2016-08-15  本文已影响2人  SpringFighting

1.导入ReactiveCocoa

platform :ios, '8.0'

target "ReactiveCocoaLearnDemo" do

use_frameworks!

pod 'ReactiveCocoa','~> 4.2.1'

end

2.学习ReactiveCocoa常见类

在RAC中最核心的类是RACSiganl

RACSiganl:信号类,一般表示将来有数据传递,只要有数据变化,信号内部接收到数据就会马上发出数据.

tips:

1.RACSiganl只是当数据改变时,信号内部会发出数据,它本事不具备发送信号的能力,而是交给内部一个订阅者去发出.

2.默认一个信号都是冷信号,也就是值改变了,也不会触发,只有订阅了这个信号(调用信号RACSiganl的subscribeNext就能订阅),这个信号才会变成热信号,值改变了才会触发.

RACSiganl的简单使用:

RACSiganl的使用步骤:

1.创建信号+(RACSignal *)createSignal:(RACDisposable * (^)(idsubscriber))didSubscribe

2.订阅信号,才会激活信号 - (RACDisposable *)subscribeNext:(void (^)(id x))nextBlock

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

// RACSignal底层实现:

// 1.创建信号,首先把didSubscribe保存到信号中,还不会触发。

// 2.当信号被订阅,也就是调用signal的subscribeNext:nextBlock

// 2.2 subscribeNext内部会创建订阅者subscriber,并且把nextBlock保存到subscriber中。

// 2.1 subscribeNext内部会调用siganl的didSubscribe

// 3.siganl的didSubscribe中调用[subscriber sendNext:@1];

// 3.1 sendNext底层其实就是执行subscriber的nextBlock


// 1.创建信号    RACSignal *siganl = [RACSignal createSignal:^RACDisposable *(idsubscriber) {

// block调用时刻:每当有订阅者订阅信号,就会调用block。

// 2.发送信号

[subscriber sendNext:@1];

// 如果不在发送数据,最好发送信号完成,内部会自动调用[RACDisposable disposable]取消订阅信号。

[subscriber sendCompleted];

return [RACDisposable disposableWithBlock:^{

// block调用时刻:当信号发送完成或者发送错误,就会自动执行这个block,取消订阅信号。

// 执行完Block后,当前信号就不在被订阅了。

NSLog(@"信号被销毁");

}];

}];

// 3.订阅信号,才会激活信号.

[siganl subscribeNext:^(id x) {

// block调用时刻:每当有信号发出数据,就会调用block.

NSLog(@"接收到数据:%@",x);

}];

RACSubscriber:表示订阅者的意思,用于发送信号,这是一个协议,不是一个类,只要遵守这个协议,并且实现方法才能成为订阅者.通过create创建的信号,都有一个订阅者,帮助它发送数据.

RACDisposable:用于取消订阅或者清理资源,当信号发送完成或者发送错误的时候,就会自动触发他.(如:不想监听某个信号的时候,可以通过它主动取消订阅信号)

RACSubject: 信号的提供者,自己可以充当信号,又能发送信号(通常用来代替代理,有了它就没必要定义代理了)

RACReplaySubject: 重复提供信号的类,RAVSubject的子类.

RACReplaySubjectRACSubject区别:RACReplaySubject可以先发送信号,再订阅信号,RACSubject就不可以(如果一个信号每被订阅一次,就需要把之前的值重复发送一遍,使用RACReplaySubject. 可以设置capacity数量来限制缓存的value的数量,即只缓充最新的几个值)

RACReplaySubject与RACSubject的简单使用:

RACSubject的使用步骤:

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

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

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

RACSubject的底层实现和RACSignal不一样

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

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

RACReplaySubject的使用步骤:

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

2.可以先订阅信号,也可以先发送信号

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

2.2发送信号 sendNext:(id)value

RACReplaySubject:底层实现和RACSubject不一样:

1.调用sendNext发送信号,把值保存起来,然后遍历刚刚保存的所有订阅者,一个一个调用订阅者的next

2.调用subscribeNext 订阅信号,遍历保存所有的值,一个一个调用订阅者的nextBlock

如果想当一个信号被订阅 ,就重复播放之前的所有值,需要先发送信号,再订阅信号

RACTuple: 元组类,类似数组,用来包装值

RACSequence:RAC中的集合类,用来替代NSArray ,NSDictionary,可以用它来快速遍历数组和字典

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

RACMulticastConnection : 用于当一个信号.被多次订阅时,为了保证创建信号时,避免多次调用创建信号中的block,造成副作用,可以使用这个类处理(通过RACSignal的-publish或者-muticast:方法创建.)

RACScheduler:RAC中的队列,用GCD封装的

RACUnit : 表示stream不包含有意义的值,看到可以理解为nil

RACEvent: 把数据包装成信号事件(signal event)。它主要通过RACSignal的-materialize来使用

ReactiveCocoa开发中常见用法

rac_signalForSelector:用于替代代理

rac_valuesAndChangesForKeyPath:用于监听某个对象的属性改变

rac_signalForControlEvents:用于监听某个事件

rac_addObserverForName:用于监听某个通知

rac_textSignal:只要文本框发出改变就会发出这个信号

处理当界面有多次请求时,需要都获取到数据时,才能展示界面

rac_liftSelector:withSignalsFromArray:Signals:当传入的Signals(信号数组),每一个signal都至少sendNext过一次,就会去触发第一个selector参数的方法。

使用注意:几个信号,参数一的方法就几个参数,每个参数对应信号发出的数据

上一篇 下一篇

猜你喜欢

热点阅读