一. 框架的导入
这里推荐使用cocoa pods,管理起来比较方便。
(1)安装 pods之后项目目录下新建Podfile文件,文件内容👇
platform:'ios', '8.0'
target 'RWReactivePlayground' do
use_frameworks!
pod 'ReactiveCocoa'
end
(2)在Build Setting中将EMBEDDED_CONTENT_CONTAINS_SWIFT
设置为YES
此时ReactiveCocoa已经导入成功!!!
二. 简单使用
在需要使用的页面中引入
#import <ReactiveCocoa/ReactiveCocoa.h>
(1)rac_textSignal 块
此方法是针对于TextField的监听,基本可省略各种输入框的delegate的方法。
例:
_textfild=[[UITextField alloc]initWithFrame:CGRectMake(20, 100, 100, 40)];
_textfild.placeholder=@"请输入";
[self.view addSubview:_textfild];
[[_textfild rac_textSignal] subscribeNext:^(id x) {
NSLog(@"%@",x);
}];
打印出来的x的值就是textfield的输入内容,并且每输入一次就会调用一次
而且如果有这种情况,在输入密码的时候,你只想在密码超过六位以后才关注他是否正确可以这样
例:
[[_textfild.rac_textSignal
filter:^BOOL(id value){
NSString*text = value;
return text.length > 6;
}]
subscribeNext:^(id x){
NSLog(@"%@", x);
}];
还有一种情况,我们只想关注用户输入了多少个字节,不想关注他的内容,这时候我们可以通过map
块来改变事件的数据
例:
[[[_textfild.rac_textSignal
map:^id(NSString*text){
return @(text.length);
}]
filter:^BOOL(NSNumber*length){
return[length integerValue] > 6;
}]
subscribeNext:^(id x){
NSLog(@"%@", x);
}];
这时候你会发现,只有在输入框的字数超过六以后才会输出,并且只是输入字数。
(2)rac_signalForControlEvents监听方法,代替addTarget
如题,此block可以监听类似于textField button等的点击方法。
例:
[[_textfild rac_signalForControlEvents:UIControlEventEditingChanged]
subscribeNext:^(id x) {
NSLog(@"%@",x);
}];
[[_button rac_signalForControlEvents:UIControlEventTouchUpInside]
subscribeNext:^(id x) {
NSLog(@"%@",x);
}];
(3)rac_signalForSelector代替代理事件
使用这个block需要传入两个参数,需要执行的方法名和需要遵守的协议,比如一个也 main需要多个alertview,如果使用代理的话,需要用tag判断是哪个alert,点击的是哪一个按钮,代码会非常繁琐,此时使用RAC,看效果👇
例:
UIAlertView * alertview=[[UIAlertView alloc]initWithTitle:@"RAC" message:@"RAC TE$XT" delegate:self cancelButtonTitle:@"queding" otherButtonTitles:@"quxaio", nil];
[[self rac_signalForSelector:@selector(alertView:clickedButtonAtIndex:) fromProtocol:@protocol(UIAlertViewDelegate)] subscribeNext:^(RACTuple *tuple) {
NSLog(@"000000===%@",tuple.first);
NSLog(@"111111===%@",tuple.second);
}];
[alertview show];
//监听点击的是哪一个按钮
[[alertview rac_buttonClickedSignal] subscribeNext:^(id x) {
NSLog(@"%@",x);
}];
此时点击alert的按钮可以发现,点击“确定”就会输出“00000”,点击另外一个同理,下面的block监听点击事件,轻松解决!!!
(4)ac_addObserverForName监听通知
这个使用起来就更简单了,注册通知正常写,在接收通知的时候
例:
[[[NSNotificationCenter defaultCenter] rac_addObserverForName:@"postData" object:nil] subscribeNext:^(NSNotification *notification) {
NSLog(@"%@",notification.name);
NSLog(@"%@",notification.object);
}];
通过打印可以知道 notification.name是通知名 notification.object是传入值,还是比较方便的,毕竟RAC的宗旨就是减少代码量。
(5)RAC的宏定义监听对象属性,代替KVO
KVO就不用多说了,监听,接受监听的方法,注销,麻烦死了,向下看👇
例:
//监听某个对象的某个属性,返回的是信号。
[RACObserve(_tryla, text) subscribeNext:^(id x) {
NSLog(@"%@",x);
}];
//用于给某个对象的某个属性绑定。
RAC(_tryla,text) = _textField.rac_textSignal;
RACObserve是RAC的一个宏,需要传入两个参数,要监听的对象和对象属性,完成监听。
(6)rac_sequence.signal便利数组和字典
// 1.遍历数组
NSArray *numbers = @[@1,@2,@3,@4];
[numbers.rac_sequence.signal subscribeNext:^(id x) {
NSLog(@"%@",x);
}];
// 2.遍历字典,遍历出来的键值对会包装成RACTuple(元组对象)
NSDictionary *dict = @{@"name":@"xmg",@"age":@18};
[dict.rac_sequence.signal subscribeNext:^(RACTuple *x) {
// 解包元组,会把元组的值,按顺序给参数里面的变量赋值
RACTupleUnpack(NSString *key,NSString *value) = x;
NSLog(@"%@ %@",key,value);
}];
就这些了,RAC功能强大无比,我了解的都只是一些皮毛而已😂😂😂