ReactiveCocoa(RAC)的简单使用

前言

RAC 5.x 版本相对于 4.x版本有了巨大的变化,由于受 swift 3.0 大升级的影响,RAC 对自身项目结构的也进行了大幅度的调整。这个调整就是将 RAC 拆分为四个库:ReactiveCocoa、ReactiveSwift、ReactiveObjC、ReactiveObjCBridge。

正确使用对应的库

1.如果你只是纯 Swift 项目,那么你继续使用 ReactiveCocoa ,但是 RAC 依赖于 ReactiveSwift ,所以等于你导入 ReactiveCocoa 和 ReactiveSwift 两个库。

2.如果你的项目是纯 OC 项目,那么你只需要使用的是 ReactiveObjC,这个库里面包含原来 RAC 2 的全部代码。

3.如果你的项目是 Swift 和 OC 混编,那么你需要使用ReactiveCocoa 和 ReactiveObjCBridge,但是 ReactiveObjCBridge 依赖于 ReactiveObjC ,所以你就等于引入了 4 个库 。

通过CocoaPods导入对应的库

1.纯 Swift 项目, podfile文件中的内容如下:

source  'https://github.com/CocoaPods/Specs.git' 

platform  :ios, '8.0'        //  系统要求

use_frameworks!       //  这个一定要添加

target   '你的项目名字'  do   // 一定要写你的项目名字

pod  'ReactiveCocoa'       // 这里默认是最新的版本

end

2.纯 OC 项目,只需要将podfile文件中的  pod  'ReactiveCocoa' 改为  pod  'ReactiveObjC'  即可

3.Swift 和 OC 混编的项目,pod  'ReactiveCocoa'  和  pod  'ReactiveObjC' 都要导入,同时需要手动导入ReactiveObjCBridge

由于我现在的项目是纯OC的,所以对应的文件如下截图:

进入主题,纯OC的项目演示

我这里新建了一个 SetFile.pch 的文件(记得要配置路径), 在这个文件中导入 头文件  #import  <ReactiveObjC/ReactiveObjC.h>  这样整个项目中就能够使用 RAC了。

RAC的每次使用都是:首先创建一个 RACSignal 信号对象,然后通过这个信号对象去订阅, 在这个信号的代理协议中发送信号, 最后在这个订阅的Block里面做相应的业务操作!!!

通过方法 createSignal:  创建信号,  通过 subscribeNext: 订阅信号 , 通过 sendNext: 发送成功信号  具体如下:

其他用法:sendError:  (发送错误信号信息)  sendCompleted (发送操作完成信号信息)  对应的订阅信号方法  subscribeError: completed: (订阅错误信号,执行操作)  subscribeCompleted: (订阅完成操作信号,执行操作)    对应的截图具体如下:

RAC中常用的功能

1.0 代替 KVO 

通过宏定义  RACObserve 或者  rac_valuesForKeyPath: observer:  (这两个方法等效) 创建RACSignal 信号对象去监听对应的属性,通过subscribeNext: 方法去订阅信号,从而要做出相应的操作。   下面的和上面同理,直接说调用的方法。

我这里声明和实现一个 Dog 类,通过监听属性 dogName 的值发生改变去执行打印操作。 代码调用和效果截图如下:

2.0 手势监听

通过创建一个 UIGestureRecognizer 手势的子类对象,再调用rac_gestureSignal 方法,然后去订阅信号,最后将手势添加到对应的视图上。

3.0 监听通知

创建一个 NSNotificationCenter  对象, 通过调用 rac_addObserverForName方法,然后去订阅信号, 最后发送一个通知。一定要先注册通知,再发送通知,有先后顺序。

4.0 监听定时器

通过调用  RACSignal 的 interval: onScheduler: 方法 设置对应的时间和执行线程,最后去订阅信号。

5.0 监听UIButton事件

通过调用 rac_signalForControlEvents: 方法,设置要监听的点击事件,最后去订阅信号。

6.0 监听UITextFiled

通过调用  rac_textSignal:方法去时刻监听文本输入框的变化, 或者通过调用 rac_signalForControlEvents: 方法(UITextFiled继承UIControl),设置要监听的事件,最后去订阅信号。

最后: Demo下载地址

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,293评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,604评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,958评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,729评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,719评论 5 366
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,630评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,000评论 3 397
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,665评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,909评论 1 299
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,646评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,726评论 1 330
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,400评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,986评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,959评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,197评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 44,996评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,481评论 2 342

推荐阅读更多精彩内容