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(进阶)的更多相关文章

  1. iOS开发之ReactiveCocoa下的MVVM(干货分享)

    最近工作比较忙,但还是出来更新博客了,今天给大家分享一些ReactiveCocoa以及MVVM的一些东西,干活还是比较足的.在之前发表过一篇博文,名字叫做<iOS开发之浅谈MVVM的架构设计与团 ...

  2. iOS 开发之 ReactiveCocoa(基础)

    前言 前段时间在看Masonry这个全新的第三方的布局框架的时候,开始了解了链式编程.后来慢慢的又开始了解函数式编程和响应式编程.在这集中的编程思想下,开始接触和研究了ReactiveCocoa这个框 ...

  3. iOS开发之ReactiveCocoa下的MVVM

    最近工作比较忙,但还是出来更新博客了,今天给大家分享一些ReactiveCocoa以及MVVM的一些东西,干活还是比较足的.在之前发表过一篇博文,名字叫做<iOS开发之浅谈MVVM的架构设计与团 ...

  4. IOS开发之SWIFT进阶部分

    概述 上一篇文章<iOS开发系列--Swift语言> 中对Swift的语法特点以及它和C.ObjC等其他语言的用法区别进行了介绍.当然,这只是Swift的入门基础,但是仅仅了解这些对于使用 ...

  5. iOS开发之MVVM在项目中的应用

    今天写这篇博客是想达到抛砖引玉的作用,想与大家交流一下思想,相互学习,博文中有不足之处还望大家批评指正.本篇博客的内容沿袭以往博客的风格,也是以干货为主,偶尔扯扯咸蛋(哈哈~不好好工作又开始发表博客啦 ...

  6. 李洪强iOS开发之iOS好文章收集

    李洪强iOS开发之iOS好文章收集 该文收集朋友们转发或自己的写的技术文章,如果你也有相关的好文章,欢迎留言,当好文章多的时候,我会对这些好文章进行分门别类 文章 简述 日期 直播服务配置 使用 ng ...

  7. iOS开发之Socket通信实战--Request请求数据包编码模块

    实际上在iOS很多应用开发中,大部分用的网络通信都是http/https协议,除非有特殊的需求会用到Socket网络协议进行网络数 据传输,这时候在iOS客户端就需要很好的第三方CocoaAsyncS ...

  8. iOS开发之UISearchBar初探

    iOS开发之UISearchBar初探 UISearchBar也是iOS开发常用控件之一,点进去看看里面的属性barStyle.text.placeholder等等.但是这些属性显然不足矣满足我们的开 ...

  9. iOS开发之UIImage等比缩放

    iOS开发之UIImage等比缩放 评论功能真不错 评论开通后,果然有很多人吐槽.谢谢大家的支持和关爱,如果有做的不到的地方,还请海涵.毕竟我一个人的力量是有限的,我会尽自己最大的努力大家准备一些干货 ...

随机推荐

  1. XSS解决方案系列之四:关于编码

    本文准备说明以下几个问题: 1. 关于重复编码的问题 2. 关于编码的多种形式的问题 3. 关于编码的几个常见问题 [说明] 本文所述编码是指encode,可以理解为转义,而不是编程序写代码. 编码或 ...

  2. 断命windows上卸载node并重装

    抠门儿世界500强给前端开发人员用windows windows不支持n模块没法自动升级 不记得何时安装的旧版本node连个uninstaller都找不到 绕道安装nvm path也自动加进去了丫命令 ...

  3. X窗口系统的协议和架构

    转自X窗口系统的协议和架构 在电脑中,X窗口系统(常称作 X11.X)是一种以位图显示的网络透明化窗口系统.本条目详述 X11 的协议及其技术架构. X C/S模型和网络透明性 X 基于C/S模型.运 ...

  4. IAR中 C语言位定义

     __IO_REG8_BIT( SYS,             0xFFFFF802, __READ_WRITE ) #define __IO_REG8_BIT(NAME, ADDRESS, A ...

  5. ubuntu 10.04 安装qt 5.0.2

    转自ubuntu 10.04 安装qt 5.0.2 从qt project网站下载下来最新的qt5.0.2套件,发现是个.run文件,添加x属性,然后直接sudo ./****.run, 提示  /l ...

  6. java线程(3)-多线程死锁

    产生死锁的条件: 1.有至少一个资源不能共享2.至少有一个任务必须持有一个资源并且等待获取另一个被别的任务持有的资源3.资源不能任务抢占4.必须有循环等待 package com.thread; /* ...

  7. lfs遇到的一些问题--后续阶段

    1.安装GPM-1.20.7,make install出错: prog/display-buttons.c:39:57: 致命错误:gpm.h:没有那个文件或目录 #include <gpm.h ...

  8. JavaScript高级程序设计59.pdf

    dropEffect和effectAllowed 利用dataTransfer对象,传输数据.确定被拖动元素以及作为放置目标的元素能够接受什么操作,为此需要访问对象的两个属性dropEffect和ef ...

  9. SWFUpload无刷新文件批量上传

    一.首先将SWFUpload所有文件加入项目中,如图

  10. Centos6 编译安装局域网NTP服务器

    一.条件及环境: 1.CentOS:我用的是最新的CentOS 6.5 64位版,此教程应该也适用于RedHat 6及CentOS 6系列所有系统: 2.编译所需环境: 1 # yum -y inst ...