iOS 开发之 ReactiveCocoa(进阶)
Map : 映射
UITextField *textField =[[UITextField alloc]initWithFrame:CGRectMake(100, 100, 100, 40)];
textField.backgroundColor =[UIColor redColor];
[self.view addSubview:textField];
[[textField.rac_textSignal map:^id(NSString * value) {
return @(value.length);
}] subscribeNext:^(NSNumber * x) {
NSLog(@"%@",x);
}];
输入Ricky:
结果:
filter: 过滤
//只有当text.length>3的时候才会订阅改消息
[[textField.rac_textSignal filter:^BOOL(NSString * text) {
return text.length>3;
}] subscribeNext:^(id x) {
NSLog(@"%@",x);
}];
同样输入Ricky结果就是:
delay:延时
//延时2秒发送消息
RACSignal *signal = [[RACSignal createSignal:^RACDisposable *(id<RACSubscriber> subscriber) {
[subscriber sendNext:@"Ricky"];
[subscriber sendCompleted];
return nil;
}] delay:2];
[signal subscribeNext:^(id x) {
NSLog(@"%@",x);
}];
startWith:在发送消息之前,先发送一个消息
RACSignal *signal = [[RACSignal createSignal:^RACDisposable *(id<RACSubscriber> subscriber) {
[subscriber sendNext:@"Ricky"];
[subscriber sendCompleted];
return nil;
}] startWith:@"RAC"];
[signal subscribeNext:^(id x) {
NSLog(@"%@",x);
}];
timeout :超时
//设置超时时间为2秒,当超过2秒还没有发送消息的时候,就不会发送了
RACSignal *signal = [[RACSignal createSignal:^RACDisposable *(id<RACSubscriber> subscriber) {
[[RACScheduler mainThreadScheduler] afterDelay:3 schedule:^{
[subscriber sendNext:@"Ricky"];
[subscriber sendCompleted];
}];
return nil;
}] timeout:2 onScheduler:[RACScheduler mainThreadScheduler]];
[signal subscribeNext:^(id x) {
NSLog(@"%@",x);
}];
take :发送多个消息的时候,取最前面的几条
RACSignal *signal = [[RACSignal createSignal:^RACDisposable *(id<RACSubscriber> subscriber) {
[subscriber sendNext:@"Ricky1"];
[subscriber sendNext:@"Ricky2"];
[subscriber sendNext:@"Ricky3"];
[subscriber sendNext:@"Ricky4"];
[subscriber sendCompleted];
return nil;
}] take:2];
[signal subscribeNext:^(id x) {
NSLog(@"%@",x);
}];
takelast :发送多个消息的时候,取最后面的几条
RACSignal *signal = [[RACSignal createSignal:^RACDisposable *(id<RACSubscriber> subscriber) {
[subscriber sendNext:@"Ricky1"];
[subscriber sendNext:@"Ricky2"];
[subscriber sendNext:@"Ricky3"];
[subscriber sendNext:@"Ricky4"];
[subscriber sendCompleted];
return nil;
}] takeLast:3];
[signal subscribeNext:^(id x) {
NSLog(@"%@",x);
}];
takeUntil: RACSignal (发送在takeUntil后面的信号完成前的消息)
// RAC这个消息是2秒后完成,所以Ricky1 Ricky2这两个消息是可以发送到 而3秒后的Ricky3 Ricky4就不会发送.
RACSignal *signal = [[RACSignal createSignal:^RACDisposable *(id<RACSubscriber> subscriber) {
[subscriber sendNext:@"Ricky1"];
[subscriber sendNext:@"Ricky2"];
dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(3 * NSEC_PER_SEC)), dispatch_get_main_queue(), ^{
[subscriber sendNext:@"Ricky3"];
[subscriber sendNext:@"Ricky4"];
[subscriber sendCompleted];
});
[subscriber sendCompleted];
return nil;
}] takeUntil:[RACSignal createSignal:^RACDisposable *(id<RACSubscriber> subscriber) {
dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(2 * NSEC_PER_SEC)), dispatch_get_main_queue(), ^{
[subscriber sendNext:@"RAC"];
[subscriber sendCompleted];
});
return nil;
}]];
[signal subscribeNext:^(id x) {
NSLog(@"%@",x);
}];
takeWhileBlock :当takeWhileBlock返回YES的时候发送消息
RACSignal *signal = [[RACSignal createSignal:^RACDisposable *(id<RACSubscriber> subscriber) {
[subscriber sendNext:@"Ricky1"];
[subscriber sendNext:@"Ricky2"];
[subscriber sendNext:@"Ricky3"];
[subscriber sendNext:@"Ricky4"];
[subscriber sendCompleted];
return nil;
}] takeWhileBlock:^BOOL(id x) {
return YES;
}];
[signal subscribeNext:^(id x) {
NSLog(@"%@",x);
}];
skip: 跳过
//跳过前2次
RACSignal *signal = [[RACSignal createSignal:^RACDisposable *(id<RACSubscriber> subscriber) {
[subscriber sendNext:@"Ricky1"];
[subscriber sendNext:@"Ricky2"];
[subscriber sendNext:@"Ricky3"];
[subscriber sendNext:@"Ricky4"];
[subscriber sendCompleted];
return nil;
}] skip:2];
[signal subscribeNext:^(id x) {
NSLog(@"%@",x);
}];
skipWhileBlcok 和 skipUntilBlcok
skipWhileBlcok:当Block返回YES的时候跳过,返回No的时候发送.
skipUntilBlcok: skipUntilBlcok和skipWhileBlcok相反,当Block返回NO的时候跳
过,返回YES的时候发送.
结合及时搜索优化
当我们在做及时搜索的时候,例如在UITextField中输入搜索内容,每当我们输入一个字符的时候当会请求服务器,无形中给服务器带来了很大的压力
UITextField *textField =[[UITextField alloc]initWithFrame:CGRectMake(100, 100, 100, 40)];
textField.backgroundColor =[UIColor redColor];
[self.view addSubview:textField];
[textField.rac_textSignal subscribeNext:^(NSString * text) {
NSLog(@"request--- %@",text);
}];
优化请求时间间隔:throttle(节流)
throttle:设置一个间隔时间,当两次信号之间的时间差下于这个时间就不会发送请求
[[textField.rac_textSignal throttle:0.3] subscribeNext:^(NSString * text) {
NSLog(@"request--- %@",text);
}];
distinctUntilChanged: 优化请求字符一样的时候(当后一个请求和前一个请求一样的时候,就可以不用请求)
[[[textField.rac_textSignal throttle:0.3]distinctUntilChanged]
subscribeNext:^(NSString * text) {
NSLog(@"request--- %@",text);
}];
ignore :忽略某些 例如上面的空字符
[[[[textField.rac_textSignal throttle:0.3]distinctUntilChanged] ignore:@"" ]
subscribeNext:^(NSString * text) {
NSLog(@"request--- %@",text);
}];
switchToLatest :当你请求数据的时候,网络会有延迟,数据还没有返回回来,这时候你发送了新的请求,则我们取消前一次的请求,只发送最新的请求.
[[[[[[textField.rac_textSignal throttle:0.3]distinctUntilChanged] ignore:@"" ] map:^id(id value) {
return [RACSignal createSignal:^RACDisposable *(id<RACSubscriber> subscriber) {
[subscriber sendNext:@"Request --- ricky"];
return nil;
}];
}] switchToLatest]
subscribeNext:^(NSString * text) {
NSLog(@"request--- %@",text);
}];
多个信号处理
RACSignal *singalA = [RACSignal createSignal:^RACDisposable *(id<RACSubscriber> subscriber) {
dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(2 * NSEC_PER_SEC)), dispatch_get_main_queue(), ^{
[subscriber sendNext:@"singalA"];
[subscriber sendCompleted];
});
return nil;
}];
RACSignal *singalB = [RACSignal createSignal:^RACDisposable *(id<RACSubscriber> subscriber) {
dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(5 * NSEC_PER_SEC)), dispatch_get_main_queue(), ^{
[subscriber sendNext:@"singalB"];
[subscriber sendCompleted];
});
return nil;
}];
merge: 同时订阅2个信号
[[singalA merge:singalB] subscribeNext:^(id x) {
NSLog(@"%@",x);
}];
singalA延迟2秒,singalB延迟5秒,她们相差了3秒.说明他们是同时发送的
concat
singalA完成后 才会订阅singalB 有点像串行队列 A失败了 B就不会被订阅
[[singalA concat:singalB] subscribeNext:^(id x) {
NSLog(@"%@",x);
}];
singalA延迟2秒,singalB延迟5秒,她们相差了5秒.说明A发送完,B才发送的.
zipWith和combineLatest:每个信号都至少要发送一次才可以被订阅.
[[singalA zipWith:singalB] subscribeNext:^(RACTuple * tuple) {
NSLog(@"%@",tuple);
}];
[[RACSignal combineLatest:@[singalA,singalB]] subscribeNext:^(RACTuple * tuple) {
NSLog(@"%@",tuple);
}];
RAC中的宏(结合例子)
UIButton中没有setbackgroundColor forstatus这个方法,使用RAC很简单实现
UIButton *button =[UIButton buttonWithType:UIButtonTypeCustom];
button.frame = CGRectMake(100, 100, 100, 100);
button.backgroundColor = [UIColor yellowColor];
[self.view addSubview:button];
RAC(button,backgroundColor) = [RACObserve(button, selected) map:^id(NSNumber * selected) {
return [selected boolValue]?[UIColor yellowColor]:[UIColor redColor];
}];
[[button rac_signalForControlEvents:UIControlEventTouchUpInside] subscribeNext:^(UIButton * x) {
x.selected = !x.selected;
}];
RAC快速实现秒表
UILabel *lab =[[UILabel alloc]initWithFrame:CGRectMake(100, 100, 200, 50)];
lab.backgroundColor =[UIColor cyanColor];
[self.view addSubview:lab];
RAC(lab,text) = [[RACSignal interval:1 onScheduler:[RACScheduler mainThreadScheduler]] map:^id(NSData * value) {
return value.description;
}];
iOS 开发之 ReactiveCocoa(进阶)的更多相关文章
- iOS开发之ReactiveCocoa下的MVVM(干货分享)
最近工作比较忙,但还是出来更新博客了,今天给大家分享一些ReactiveCocoa以及MVVM的一些东西,干活还是比较足的.在之前发表过一篇博文,名字叫做<iOS开发之浅谈MVVM的架构设计与团 ...
- iOS 开发之 ReactiveCocoa(基础)
前言 前段时间在看Masonry这个全新的第三方的布局框架的时候,开始了解了链式编程.后来慢慢的又开始了解函数式编程和响应式编程.在这集中的编程思想下,开始接触和研究了ReactiveCocoa这个框 ...
- iOS开发之ReactiveCocoa下的MVVM
最近工作比较忙,但还是出来更新博客了,今天给大家分享一些ReactiveCocoa以及MVVM的一些东西,干活还是比较足的.在之前发表过一篇博文,名字叫做<iOS开发之浅谈MVVM的架构设计与团 ...
- IOS开发之SWIFT进阶部分
概述 上一篇文章<iOS开发系列--Swift语言> 中对Swift的语法特点以及它和C.ObjC等其他语言的用法区别进行了介绍.当然,这只是Swift的入门基础,但是仅仅了解这些对于使用 ...
- iOS开发之MVVM在项目中的应用
今天写这篇博客是想达到抛砖引玉的作用,想与大家交流一下思想,相互学习,博文中有不足之处还望大家批评指正.本篇博客的内容沿袭以往博客的风格,也是以干货为主,偶尔扯扯咸蛋(哈哈~不好好工作又开始发表博客啦 ...
- 李洪强iOS开发之iOS好文章收集
李洪强iOS开发之iOS好文章收集 该文收集朋友们转发或自己的写的技术文章,如果你也有相关的好文章,欢迎留言,当好文章多的时候,我会对这些好文章进行分门别类 文章 简述 日期 直播服务配置 使用 ng ...
- iOS开发之Socket通信实战--Request请求数据包编码模块
实际上在iOS很多应用开发中,大部分用的网络通信都是http/https协议,除非有特殊的需求会用到Socket网络协议进行网络数 据传输,这时候在iOS客户端就需要很好的第三方CocoaAsyncS ...
- iOS开发之UISearchBar初探
iOS开发之UISearchBar初探 UISearchBar也是iOS开发常用控件之一,点进去看看里面的属性barStyle.text.placeholder等等.但是这些属性显然不足矣满足我们的开 ...
- iOS开发之UIImage等比缩放
iOS开发之UIImage等比缩放 评论功能真不错 评论开通后,果然有很多人吐槽.谢谢大家的支持和关爱,如果有做的不到的地方,还请海涵.毕竟我一个人的力量是有限的,我会尽自己最大的努力大家准备一些干货 ...
随机推荐
- bzoj 3160: 万径人踪灭 manachar + FFT
3160: 万径人踪灭 Time Limit: 10 Sec Memory Limit: 256 MBSubmit: 133 Solved: 80[Submit][Status][Discuss] ...
- 码云分布式之 Brzo 服务器
摘要: 码云是国内最大的代码托管平台,为了支持更大的用户规模,开发团队也在对一些组件进行大规模的重构. 前言 码云是国内最大的代码托管平台.码云基于 Gitlab 5.5 开发,经过几年的开发已经和官 ...
- 【Xamarin挖墙脚系列:时刻下载最新的Mac环境下的Xamarin安装包】
原文:[Xamarin挖墙脚系列:时刻下载最新的Mac环境下的Xamarin安装包] 打开这两个地址,就能看到最新的安装包了.... http://www.jianshu.com/p/c67c14b3 ...
- 在服务 ObtainData 实现的协定列表中找不到协定名称 "IMetadataExchange"。将 ServiceMetadataBehavior 添加到配置文件或直接添加到 ServiceHost,以启用对该协定的支持。
第一种解决方法:最暴力的 配置去掉<endpoint address="mex" binding="mexHttpBinding" contract=&q ...
- linux上TCP connection timeout的原因查找
linux上TCP connection timeout的原因查找 好久没有写文章了, 今天解决了一个网络连接超时的问题, 记录以备查看. 最近在线上nginx经常出现输出connection tim ...
- hadoop2.2编程: Interation
继承关系: 1.java.lang.Object |_ org.apache.hadoop.io.BinaryComparable |_ org.apache.hadoop.io.Text //des ...
- [C# 网络编程系列]专题十:实现简单的邮件收发器
转自:http://www.cnblogs.com/zhili/archive/2012/09/24/2689892.html 引言: 在我们的平常工作中,邮件的发送和接收应该是我们经常要使用到的功能 ...
- log4net.dll配置以及在项目中应用 zt
1 首先在项目中引用log4net.dll,然后项目中添加一个配置文件log4net.config <?xml version="1.0" encoding="ut ...
- TeamViewer 远程时出现:现在无法捕捉画面。这可能是由于恰的用户切换或远程桌面会话断开、最小化
关掉远程访问主机的TeamViewer ,再重新打开软件
- 【转】qtp安装时问题
1.安装qtp后要重启机器. 2.插件选择错误, 处理方式:重新启动QTP,勾选 WEB插件; 3.在安装QTP后,或者禁用IE浏览器里的一些ActiveX控件后,正常录制QTP时,对象识别不了;(保 ...