ReactiveCocoa基本使用

ReactivieCocoa的底层就不说明了。这里就简单介绍它的几个基本使用场景。

Cocoapods导入ReactiveCocoa5.0以上版本注意事项

1、如果你使用的是纯swift工程,podfile文件描述如下:

use_frameworks!
target ‘工程名称‘ do
pod ‘ReactiveCocoa‘, ‘5.0.0-alpha.3‘
end

2、如果你使用的是纯oc工程,podfile文件描述如下:

use_frameworks!
target ‘工程名称‘ do
pod ‘ReactiveObjC‘, ‘~> 2.1.0‘
end

3、如果你使用oc与swift混合编程,podfile文件描述如下:

use_frameworks!
target ‘工程名称‘ do
pod ‘ReactiveObjC‘, ‘~> 2.1.0‘
pod ‘ReactiveCocoa‘, ‘5.0.0-alpha.3‘
end

基本使用 

p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 12.0px Menlo; color: #d12f1b }
span.s1 { color: #78492a }
span.s2 { }

#import <ReactiveObjC/ReactiveObjC.h>

一、替代代理,代码就是这么的简单,如果传递多个值的话 x是一个RACTuple(元组)对象,这个对象在下面说明,如果值传一个值,那么传的是什么对象,x就是什么对象。

//redView 是在控制器view的子视图,在redView中响应一个事件,把需要的消息从redView传递到控制器过来
    //这段代码是在控制器viewController.m中订阅redView的btnClick事件消息
    //如果传递多个值的话 x是一个RACTuple(元组)对象,比如@selector(clickWithValue1:value2:)
    [[_redVeiw rac_signalForSelector:@selector(btnClick:)] subscribeNext:^(id  _Nullable x) {
        NSLog(@"x:%@",x);
    }];

二、代替KVO

/**
     用法和原生代码基本一致valuesForKeyPath: observer:
     self 是viewController
     age  是self的一个属性
     @param x 是age改变后的值
     */
    [[self rac_valuesForKeyPath:@"age" observer:nil] subscribeNext:^(id  _Nullable x) {
        NSLog(@"x ::%@",x);
    }];

三、事件监听

//_btn 是一个按钮,给按钮添加一个事件。不需要像原生那样addTarget:action:forControlEvents:,然后再写一个方法给action这么麻烦了。
    [[_btn rac_signalForControlEvents:UIControlEventTouchUpInside]subscribeNext:^(__kindof UIControl * _Nullable x) {
        NSLog(@"x:::%@",x);
    }];

四、代替通知

//这个用法就和系统一样了,只是把监听处理的代码聚合在一起,不需要另外写一个方法,提高代码阅读性。
    //我这里是监听了一个键盘弹起的一个通知。
    [[[NSNotificationCenter defaultCenter] rac_addObserverForName:UIKeyboardWillShowNotification object:nil] subscribeNext:^(NSNotification * _Nullable x) {
        NSLog(@"键盘起来了:%@",x);
    }];

五、输入框改变监听

//这个使用方式和给按钮添加事件监听差不多。这里ControlEvents不需要填了,监听textField的text的改变
    [_textfield.rac_textSignal subscribeNext:^(NSString * _Nullable x) {
        NSLog(@"textfield改变了:%@",x);
    }];

六、处理几个信号完成后统一处理事件。 比如说:我们在一个界面有几个不同的网络数据请求,我们需要监听他们都请求完成后才处理一些事情,那么就可以使用以下方式。

//创建信号1
    RACSignal * signalA = [RACSignal createSignal:^RACDisposable * _Nullable(id<RACSubscriber>  _Nonnull subscriber) {
        //处理信号 。。 正在发送请求1.。
        /*
         网络请求代码。。。
        */
        //请求完成后,发送数据
        [subscriber sendNext:@"请求1完成"];
        return nil;
    }];
    //创建信号2
    RACSignal * signalB = [RACSignal createSignal:^RACDisposable * _Nullable(id<RACSubscriber>  _Nonnull subscriber) {
        //处理信号 。。 正在发送请求2.。
        /*
         网络请求代码。。。
         */
        //请求完成后,发送数据
        [subscriber sendNext:@"请求2完成"];
        return nil;
    }];

    //监听 signalA 和 signalB 两个信号都完成了才调用request1WithContent:request2WithContent:
    //注意request1WithContent:request2WithContent:是自己写的一个方法,但是这个方法有个原则,就是有几个信号,就对应传递几个值,不可以多,也不可以少,否则运行的时候就会崩溃,报方法错误(参数错误)
    [self rac_liftSelector:@selector(request1WithContent:request2WithContent:) withSignalsFromArray:@[signalA,signalB]];
/**
 请求1和请求都完成了
 */
-(void)request1WithContent:(NSString *)content1 request2WithContent:(NSString *)content2{
    NSLog(@"请求1内容:%@",content1);
    NSLog(@"请求2内容:%@",content2);
}

七、RACTuple元组对象,在第一步代替代理的时候提及过。元组对象和我们的数组对象差不多,使用方法也比较简单,ARC提供了几个宏来创建以及解包。

/**
     元组
     */
    RACTuple * tuple = RACTuplePack(@1,@2,@3);//使用RACTuplePack宏来快速创建
    NSLog(@"TUPLE:%@",tuple);

    //使用RACTupleUnpack宏快速解包
    RACTupleUnpack(NSNumber *num1,NSNumber *num2,NSNumber *num3) = tuple;
    NSLog(@"num1:%@",num1);
    NSLog(@"num2:%@",num2);
    NSLog(@"num3:%@",num3);

    //使用下标的方式来获取
    NSLog(@"第0个:%@",tuple[0]);

上面介绍了 RACTuplePack RACTupleUnpack 两个宏的使用,下面再介绍几个常用的宏

1、RAC 绑定一个信号

//1、RAC 把一个对象的摸个属性绑定一个信号,只有发出信号,就会吧信号的内容给对象的属性赋值。
    //这里吧label的text属性绑定到textField改变信号中,textfield的内容发生改变的时候就会发出信号,label的text就会跟随着改变。
    RAC(self.label,text) = _textfield.rac_textSignal;

2、RACObserve  相当于kvo使用

//2、KVO
    /**
     @param self 是viewController
     @param age self的一个属性
     */
    [RACObserve(self, age) subscribeNext:^(id  _Nullable x) {
        NSLog(@"x:%@",x);
    }];

3、@weakify 和@strongify   这个就是为了解决在使用block的时候强引用问题,注意这两个宏是配套使用才有效。

//3、把一个对象转换成弱指针
    @weakify(self);//self 是viewController 在block外面使用@weakify
   self.signal = [RACSignal createSignal:^RACDisposable * _Nullable(id<RACSubscriber>  _Nonnull subscriber) {
       //在block里面再使用@strongify
       @strongify(self);
       NSLog(@"%@,",self.view);
        return nil;
    }];
时间: 2024-07-30 03:23:00

ReactiveCocoa基本使用的相关文章

ReactiveCocoa框架下的MVVM模式解读

记录一些MVVM文章中关于ReactiveCocoa的代码: 实例一:带有分页的文章列表,根据文章类别过滤出文章的列表,可以进入文章详细页面 1:YFBlogListViewModel 首先了解关于列表的ViewModel的代码内容: #import <Foundation/Foundation.h> #import <ReactiveCocoa.h> @class YFCategoryArticleListModel; /** * 文章列表的视图模型. */ @interface

ReactiveCocoa / RxSwift 笔记一

原创:转载请注明出处 ReactiveCocoa / RxSwift Native app有很大一部分的时间是在等待事件发生,然后响应事件,比如 1.等待网络请求完成, 2.等待用户的操作, 3.等待某些状态值的改变等等, 等这些事件发生后,再做进一步处理 但是这些等待和响应,并没有一个统一的处理方式.Delegate, Notification, Block, KVO, 常常会不知道该用哪个最合适.有时需要chain或者compose某几个事件,就需要多个状态变量,而状态变量一多,复杂度也就上

RAC(ReactiveCocoa)

什么是 ReactiveCocoa ReactiveCocoa(其简称为 RAC)是由 Github 开源的一个应用于 iOS 和 OS X 开发的新框架.RAC 具有函数式编程和响应式编程的特性.它主要吸取了 .Net 的 Reactive Extensions 的设计和实现. ReactiveCocoa 试图解决什么问题 经过一段时间的研究,我认为 ReactiveCocoa 试图解决以下 3 个问题: 传统 iOS 开发过程中,状态以及状态之间依赖过多的问题 传统 MVC 架构的问题:Co

ReactiveCocoa 谈谈concat

今天的一个业务流程,业务流程大概就是这样的 1.从CoreData中获取之前的数据 2.更新界面 3.从网络获取数据 4.判断获取结果 5.处理错误判断 6.更新界面 7.判断结果numberOfNews字段 8.现实numberOfNews信息 这种顺序行的处理,正正是ReactiveCocoa的擅长解决的问题,那么问题来了,怎么才能通过Signal,将if else 转换数据,要知道,很多地方都在block里面 这就需要用到flattenMap 和 then 这两个东西 来看看React的玩

Reactivecocoa初级使用

一直听闻ReactiveCocoa(以下简称RAC)的大名,但始终没有使用.最近时间比较空闲就决定研究一下. 在配置RAC时候遇到了一个小麻烦需要说明本人用cocoapods管理第三方框架,于是按照正常流程在终端中 输入pod search ReactiveCocoa,找到搜索结果 于是vim 打开Podfile 录入 pod 'ReactiveCocoa', '~> 3.0.0-alpha.1' 结果cocoapods始终安装不了 原因竟是3.0.0支持的是swift 于是重新录入pod 'R

ReactiveCocoa内存管理

1.我们创建的管道是如何被保存的么? ReactiveCocoa设计的目的之一是允许这样一种编程样式,即管道可以匿名创建.到目前为止,我们的管道都是这么处理的.为了支持这种模式,ReactiveCocoa维护了一个全局的信号集合.如果信号有一个或多个订阅者,它就是可用的.如果所有订阅者都被移除了,信号就被释放了. 2.如何取消对信号的订阅? 在一个completed事件或error事件后,一个订阅者会自动将自己移除.手动移除可能通过RACDisposable来完成.RACSignal的所有订阅方

iOS开发ReactiveCocoa学习笔记(四)

ReactiveCocoa常见操作方法介绍: demo地址:https://github.com/SummerHH/ReactiveCocoa.git p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 11.0px Menlo; color: #008400 } p.p2 { margin: 0.0px 0.0px 0.0px 0.0px; font: 11.0px Menlo; color: #008400; min-height: 13.0px }

iOS开发ReactiveCocoa学习笔记(二)

RAC 中常见的宏: 使用宏定义要单独导入 #import <RACEXTScope.h> 一. RAC(TARGET, [KEYPATH, [NIL_VALUE]]):用于给某个对象的某个属性绑定 只要文本框文字改变,就会修改label的文字 RAC(self.labelView,text) = _textField.rac_textSignal; 二. RACObserve(self, name):监听某个对象的某个属性,返回的是信号. [RACObserve(self.view, cen

iOS开发ReactiveCocoa学习笔记(-)

学习 RAC 我们首先要了解 RAC 都有哪些类 RACSignal RACSubject RACSequence RACMulticastConnection RACCommand 在学习的时候写了一个小 demo 来分别介绍每个类的作用,gitHub 地址: https://github.com/SummerHH/ReactiveCocoa.git demo 的目录结构如下 RAC学习起来的特点 学习起来比较难 团队开发的时候需要谨慎使用 团队代码需要不断的评审,保证团队中所有人代码的风格一

ReactiveCocoa学习

ReactiveCocoa常见类 6.1RACSiganl:信号类,一般表示将来有数据传递,只要有数据改变,信号内部接收到数据,就会马上发出数据. 注意: 信号类(RACSiganl),只是表示当数据改变时,信号内部会发出数据,它本身不具备发送信号的能力,而是交给内部一个订阅者去发出. 默认一个信号都是冷信号,也就是值改变了,也不会触发,只有订阅了这个信号,这个信号才会变为热信号,值改变了才会触发. 如何订阅信号:调用信号RACSignal的subscribeNext就能订阅. RACSigan