一,它是什么
ReactiveCocoa是响应式编程(FRP)在IOS中的一个实现框架,就是用信号接管了iOS 中的所有事件。英文比较好的小伙伴可以直接去github上看它的官方说明。地址:https://github.com/ReactiveCocoa/ReactiveCocoa
可以把信号想象成水龙头,只不过里面不是水,而是玻璃球(value),直径跟水管的内径一样,这样就能保证玻璃球是依次排列,不会出现并排的情况(数据都是线性处理的,不会出现并发情况)。水龙头的开关默认是关的,除非有了接收方(subscriber),才会打开。这样只要有新的玻璃球进来,就会自动传送给接收方。可以在水龙头上加一个过滤嘴(filter),不符合的不让通过,也可以加一个改动装置,把球改变成符合自己的需求(map)。也可以把多个水龙头合并成一个新的水龙头(combineLatest:reduce:),这样只要其中的一个水龙头有玻璃球出来,这个新合并的水龙头就会得到这个球。
ReactiveCocoa整体可以分为四个部分
信号源(事件流) RACStream
订阅者 RACSubscriber
调度器 RACScheduler
清洁工 RACDisposable
二,它的用途
为了提高我们的开发效率。RAC在某些特定情况下开发时可以大大简化代码,并且目前来看安全可靠。在RAC的世界中,以事件流(用Signal、SignalProductor来表示)的形式,组合和转换信号,最终得到我们想要的输出,代码大统一。
1.传统iOS开发过程中,状态以及状态之间依赖过多的问题
2.传统MVC架构的问题:Controller比较复杂,可测试性差
3.提供统一的消息传递机制
三,它的使用
引用中的第一篇和第五篇讲的比较生动,具体,建议大家去看下那里面对它的实际应用。
* 1 RAC发送消息,并且绑定到控件
#pragma -mark 文本框输入事件监听
/**
* 2、为了测试此函数,增加了一个nameText;监听文本框的输入内容,并设置为self.person.name
*/
- (void)demoTextField {
@weakify(self);
[[self.nameText rac_textSignal]
subscribeNext:^(id x) {
@strongify(self);
NSLog(@"%@",x);
self.person.name = x;
}];
}
按钮监听
#pragma -mark 按钮监听
/**
* 4、验证此函数:当loginButton可以点击时,点击button输出person的属性,实现监控的效果
*/
- (void)buttonDemo {
@weakify(self);
[[self.loginButton rac_signalForControlEvents:UIControlEventTouchUpInside]
subscribeNext:^(id x) {
@strongify(self);
NSLog(@"person.name: %@ person.password: %@",self.person.name,self.person.password);
}
];
}
* 2 RAC代理
- (void)racProtocol {
RACSignal *programmerSignal = [self rac_signalForSelector:@selector(whoAmI) fromProtocol:@protocol(Programmer)];
[programmerSignal subscribeNext:^(id x) {
NSLog(@"RAC通知------I'm a great programmer...");
}];
@weakify(self);
dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(2.0 * NSEC_PER_SEC)), dispatch_get_main_queue(), ^{
[self_weak_ whoAmI];
});
}
- (void)whoAmI {
NSLog(@"whoAmI------my name is %@",_user.userName);
}
demo2
#pragma -mark 代理方法
/** * 5、验证此函:nameText的输入字符时,输入回撤或者点击键盘的回车键使passWordText变为第一响应者(即输入光标移动到passWordText处) */
- (void)delegateDemo {
@weakify(self)
// 1. 定义代理
self.proxy = [[RACDelegateProxy alloc]initWithProtocol:@protocol(UITextFieldDelegate)];
// 2. 代理去注册文本框的监听方法
[[self.proxy rac_signalForSelector:@selector(textFieldShouldReturn:)] subscribeNext:^(id x) {
@strongify(self)
if (self.nameText.hasText) {
[self.passWordText becomeFirstResponder];
} }];
self.nameText.delegate = (id)self.proxy;
}
* 3 RAC通知
- (void)racNotification {
//接受通知并且处理
[[[NSNotificationCenter defaultCenter] rac_addObserverForName:@"RAC_Notifaciotn" object:nil] subscribeNext:^(NSNotification *notify) {
NSLog(@"notify.content = %@",notify.userInfo[@"content"]);
}];
//发出通知
[[NSNotificationCenter defaultCenter] postNotificationName:@"RAC_Notifaciotn" object:nil userInfo:@{@"content" : @"i'm a notification"}];
}
*4 RAC观察者模式(KVO)
@weakify(self);
[RACObserve(self, value) subscribeNext:^(NSString* x) {
@strongify(self);
NSLog(@"你动了");
}];
四,注意事项
在RAC的block中使用self,很容易造成循环泄漏,所以要使用@weakify和@strongify
五,引用的文章链接
这样好用的ReactiveCocoa,根本停不下来(非常推荐!!!)