ReactiveCocoa是响应式编程(FRP)在iOS中的一个实现框架,它的开源地址为:https://github.com/ReactiveCocoa/ReactiveCocoa# ;在网上看了几篇文章,感觉理论讲了很多,但是代码还是看不太懂,于是自己把它github文档上的一些使用的经典示例实现了一下,项目中有需要时可以直接搬过去用,用的熟练了再读源码也比较容易理解。

例1. 监听对象的成员变量变化,当成员变量值被改变时,触发做一些事情。

这种情况其实就是IOS KVO机制使用的场景,使用KVO实现,通常有三个步骤:1,给对象的成员变量添加监听;2,实现监听回调;3,取消监听;而通过RAC可以直接实现,RAC的回调是通过block实现的,类似于过程式编程,上下文也更容易理解一些。

场景:当前类有一个成员变量 NSString *input,当它的值被改变时,发送一个请求。

实现:

  1. [RACObserve(self, input)
  2. subscribeNext:^(NSString* x){
  3. request(x);//发送一个请求
  4. }];

每次input值被修改时,就会调用此block,并且把修改后的值做为参数传进来。

场景:在上面场景中,当用户输入的值以2开头时,才发请求.

实现:

  1. [[RACObserve(self, input)
  2. filter:^(NSString* value){
  3. if ([value hasPrefix:@"2"]) {
  4. return YES;
  5. } else {
  6. return NO;
  7. }
  8. }]
  9. subscribeNext:^(NSString* x){
  10. request(x);//发送一个请求
  11. }];

场景:上面场景是监听自己的成员变量,如果想监听UITextField输入值变化,框架也做了封装可以代替系统回调

实现:

  1. [[self.priceInput.rac_textSignal
  2. filter:^(NSString *str) {
  3. if (str.integerValue > 20) {
  4. return YES;
  5. } else {
  6. return NO;
  7. }
  8. }]
  9. subscribeNext:^(NSString *str) {
  10. <span style="white-space:pre">    </span>request(x);//发送一个请求

}];


例2. 同时监听多个变量变化,当这些变量满足一定条件时,使button为可点击状态

场景:button监听 两个输入框有值和一个成员变量值,当输入框有输入且成员变量为真时,button为可点击状态

实现:

  1. RAC(self.payButton,enabled) = [RACSignal
  2. combineLatest:@[self.priceInput.rac_textSignal,
  3. self.nameInput.rac_textSignal,
  4. RACObserve(self, isConnected)
  5. ]
  6. reduce:^(NSString *price, NSString *name, NSNumber *connect){
  7. return @(price.length > 0 && name.length > 0 && [connect boolValue]);
  8. }];

场景:满足上面条件时,直接发送请求

实现:

  1. [[RACSignal
  2. combineLatest:@[self.priceInput.rac_textSignal,
  3. self.nameInput.rac_textSignal,
  4. RACObserve(self, isConnected)
  5. ]
  6. reduce:^(NSString *price, NSString *name, NSNumber *connect){
  7. return @(price.length > 0 && name.length > 0 && ![connect boolValue]);
  8. }]
  9. subscribeNext:^(NSNumber *res){
  10. if ([res boolValue]) {
  11. NSLog(@"XXXXX send request");
  12. }
  13. }];

例3. 类似于生成产-消费

场景:用户每次在TextField中输入一个字符,1秒内没有其它输入时,去发一个请求。TextField中字符改变触发事件已在例1中展示,这里实现一下它触法的方法,把1秒延时在此方法中实现。

实现:

  1. - (void)showLoading {
  2. [self.loadingDispose dispose];//上次信号还没处理,取消它(距离上次生成还不到1秒)
  3. @weakify(self);
  4. self.loadingDispose = [[[RACSignal createSignal:^RACDisposable *(id<RACSubscriber> subscriber) {
  5. [subscriber sendCompleted];
  6. return nil;
  7. }] delay:1] //延时一秒
  8. subscribeCompleted:^{
  9. @strongify(self);
  10. doRequest();
  11. self.loadingDispose = nil;
  12. }];
  13. }

上面代码看起来挻费解,不过下面一段类似的代码拆开写的,会比较容易理解:

  1. [self.loadingDispose dispose];
  2. RACSignal *loggingSignal = [RACSignal createSignal:^ RACDisposable * (id<RACSubscriber> subscriber) {//BLOCK_1
  3. subscriptions++;
  4. [subscriber sendNext:@"mytest"];
  5. [subscriber sendCompleted];
  6. return nil;
  7. }];
  8. loggingSignal = [loggingSignal delay:10];
  9. self.loadingDispose = [loggingSignal subscribeNext:^(NSString* x){//BLOCK_2
  10. NSLog(@"%@",x);
  11. NSLog(@"subscription %u", subscriptions);
  12. }];
  13. self.loadingDispose = [loggingSignal subscribeCompleted:^{//BLOCK_3
  14. NSLog(@"subscription %u", subscriptions);
  15. }];

loggingSignal在每次被调用subscriibeNext:^(id x)或subscribeCompleted:^方法时(12行和17行),它创建进传进的参数block_1就会被触动发,而block_1中的sendNext:方法会调用subscriibeNext:^中对应的block_2, 而block_1中的sendCompleted会调用subscribeCompleted:中对应的block_3

IOS响应式编程框架ReactiveCocoa(RAC)使用示例的更多相关文章

  1. IOS响应式编程框架ReactiveCocoa(RAC)使用示例-备

    ReactiveCocoa是响应式编程(FRP)在IOS中的一个实现框架,它的开源地址为:https://github.com/ReactiveCocoa/ReactiveCocoa# :在网上看了几 ...

  2. iOS响应式编程:ReactiveCocoa vs RxSwift 选谁好

    转载: iOS响应式编程:ReactiveCocoa vs RxSwift 选谁好 内容来自stack overflow的一个回答:ReactiveCocoa vs RxSwift – pros an ...

  3. [iOS] 响应式编程开发-ReactiveCocoa(一)

    什么是响应式编程 响应式编程是一种面向数据流和变化传播的编程范式.这意味着可以在编程语言中很方便地表达静态或动态的数据流,而相关的计算模型会自动将变化的值通过数据流进行传播. 例如,在命令式编程环境中 ...

  4. [iOS] 响应式编程开发-ReactiveCocoa(二)

    RAC实现图片下载功能 在实现异步RAC下载图片的过程中,需要注意以下几点: • 通过 NSURLConnection 对象的 +(RACSignal *)rac_sendAsynchronousRe ...

  5. 响应式布局框架 Pure-CSS 5.0 示例中文版-上

    0. Pure-CSS 介绍 Pure CSS 是雅虎出品的 CSS 框架, 依托于Normalize.CSS,在不适用任何JS代码情况下即可实现响应式布局的轻量级框架,无依赖,体积小. 1. CDN ...

  6. 响应式布局框架 Pure-CSS 5.0 示例中文版-中

    8. 表单 Form 在 form 标签中添加 .pure-form 类,可生成单行表单(inline) 效果图: 代码: <form class="pure-form"&g ...

  7. 响应式布局框架 Pure-CSS 5.0 示例中文版-下

    10. 表格 Tables 在 table 标签增加 .pure-table 类 <table class="pure-table"> <thead> &l ...

  8. ReactiveCocoa,最受欢迎的iOS函数响应式编程库(2.5版),没有之一!

    简介 项目主页: ReactiveCocoa 实例下载: https://github.com/ios122/ios122 简评: 最受欢迎,最有价值的iOS响应式编程库,没有之一!iOS MVVM模 ...

  9. [转帖]浅谈响应式编程(Reactive Programming)

    浅谈响应式编程(Reactive Programming) https://www.jianshu.com/p/1765f658200a 例子写的非常好呢. 0.9312018.02.14 21:22 ...

随机推荐

  1. MongoDB学习记录

    一.操作符 "$lt" :"<""$lte" :"<=""$gt" :"> ...

  2. Maven项目WEB-INF/views无法引入js,css静态文件解决方法

    web.xml针对文件后缀配置以下,对客户端请求的静态资源如图片.JS文件等的请求交由默认的servlet进行处理 <servlet-mapping> <servlet-name&g ...

  3. 《UML大战需求分析》阅读笔记04

    在学习了前面的几种UML图并不能满足所有情况的建模,如当流程图涉及到多种角色,并且通过对多种角色交互展开时,顺序图才是不二选择.顺序图就如同中文语法的说话语言相似,描述的是一种事件发生的顺序.顺序图分 ...

  4. 总结-jQuery

    一.ajax提交,如果某个变量的值填的是doc对象,jQuery不报错,也没有反应,如: {userName : $('#userName')}.正确的写法 {userName : $('#userN ...

  5. MyBatis学习总结(五)——实现关联表查询(转载)

    本文转载自:http://www.cnblogs.com/jpf-java/p/6013516.html 一.一对一关联 1.1.提出需求 根据班级id查询班级信息(带老师的信息) 1.2.创建表和数 ...

  6. angular前端开发环境

    1.代码编辑工具 webstorm 2.断点调试工具 chrome插件Batarang 3.版本管理工具 git(仅仅是命令行工具) git小乌龟--tortoisegit(图形化工具) 首先在git ...

  7. Emmet使用

    emmet官方文档 [翻译]Emmet (ZenCoding) 缩写语法 <!-- ul>li.item$*5 --> <ul> <li class="i ...

  8. [css 揭秘]-css coding tips

    css 揭秘之css coding tips demo(1) html 代码: <body> <section> <div class="demo1" ...

  9. 级联两个bootstrap-table。一张表显示相关的数据,通过点击这张表的某一行,传过去对应的ID,刷新另外一张表。

    二张表的代码(我用的插件,大家可以去网上直接下载http://issues.wenzhixin.net.cn/bootstrap-table/): <div class="contai ...

  10. typealias和泛型接口

    typealias 是用来为已经存在的类型重新定义名字的,通过命名,可以使代码变得更加清晰.使用的语法也很简单,使用 typealias 关键字像使用普通的赋值语句一样,可以将某个已经存在的类型赋值为 ...