遍历数组
NSArray *numbers = @[@1,@2,@3,@4];
// 这里其实是三步
// 第一步: 把数组转换成集合RACSequence numbers.rac_sequence
// 第二步: 把集合RACSequence转换RACSignal信号类,numbers.rac_sequence.signal
// 第三步: 订阅信号,激活信号,会自动把集合中的所有值,遍历出来。
[numbers.rac_sequence.signal subscribeNext:^(id x) {
NSLog(@"%@",x);
}];
遍历字典
//遍历字典,遍历出来的键值对会包装成RACTuple(元组对象)
NSDictionary *dict = @{@"name":@"xmg",@"age":@18};
[dict.rac_sequence.signal subscribeNext:^(RACTuple *x) {
// 解包元组,会把元组的值,按顺序给参数里面的变量赋值
RACTupleUnpack(NSString *key,NSString *value) = x;
// 相当于以下写法
// NSString *key = x[0];
// NSString *value = x[1];
NSLog(@"%@ %@",key,value);
}];
替代delegate(UIAlertView)
//代替代理 ----> rac_signalForSelector:用于替代代理
UIAlertView *alertView = [[UIAlertView alloc] initWithTitle:@"RAC" message:@"RAC TEST" delegate:self cancelButtonTitle:@"cancel" otherButtonTitles:@"other1",@"other2",@"other3", nil];
[[self rac_signalForSelector:@selector(alertView:clickedButtonAtIndex:) fromProtocol:@protocol(UIAlertViewDelegate)] subscribeNext:^(RACTuple *tuple) {
NSLog(@"%@",tuple.first);
NSLog(@"%@",tuple.second);
NSLog(@"%@",tuple.third);
}];
[alertView show];
[[alertView rac_buttonClickedSignal] subscribeNext:^(id x) {
NSLog(@"%@",x);
}];
替代KVO
//rac_valuesAndChangesForKeyPath:用于监听某个对象的属性改变。
//RAC中得KVO大部分都是宏定义,所以代码异常简洁,简单来说就是RACObserve(TARGET, KEYPATH)这种形式,TARGET是监听目标,KEYPATH是要观察的属性值,这里举一个很简单的例子,如果UIScrollView滚动则输出success。
UIScrollView *scrolView = [[UIScrollView alloc] initWithFrame:CGRectMake(0, 0, 200, 400)];
scrolView.contentSize = CGSizeMake(200, 800);
scrolView.backgroundColor = [UIColor greenColor];
[self.view addSubview:scrolView];
[RACObserve(scrolView, contentOffset) subscribeNext:^(id x) {
CGPoint p = [x CGPointValue];
NSLog(@"success ----> x=%.2f y=%.2f", p.x, p.y);
}];
监听事件(button/view)
//rac_signalForControlEvents:用于监听某个事件。
// 把按钮点击事件转换为信号,点击按钮,就会发送信号
UIButton *button =[[UIButton alloc] initWithFrame:CGRectMake(300, 300, 50, 50)];
[self.view addSubview:button];
button.backgroundColor = [UIColor orangeColor];
[[button rac_signalForControlEvents:UIControlEventTouchUpInside] subscribeNext:^(id x) {
NSLog(@"按钮被点击了");
}];
//给Lable或者View添加监听
UILabel *textLab = [[UILabel alloc] initWithFrame:CGRectMake(100, 100, 200, 30)];
textLab.backgroundColor = [UIColor greenColor];
textLab.text = @"********************";
textLab.userInteractionEnabled = YES;
[self.view addSubview:textLab];
//手势
UITapGestureRecognizer *tap = [[UITapGestureRecognizer alloc] init];
[textLab addGestureRecognizer:tap];
[[tap rac_gestureSignal] subscribeNext:^(id x) {
NSLog(@"点击Lab");
}];
TextField
//rac_textSignal:只要文本框发出改变就会发出这个信号。
UITextField *text1 = [[UITextField alloc] initWithFrame:CGRectMake(100, 200, 200, 30)];
text1.backgroundColor = [UIColor cyanColor];
[self.view addSubview:text1];
[[text1 rac_textSignal] subscribeNext:^(id x) {
static int i = 0;
i++;
// text改变就会打印
NSLog(@"厉害了我的哥------ %d", i);
}];
处理当界面有多次请求时,需要都获取到数据时,才能展示界面
- (void)viewDidLoad {
[super viewDidLoad];
//rac_liftSelector:withSignalsFromArray:Signals:当传入的Signals(信号数组),每一个signal都至少sendNext过一次,就会去触发第一个selector参数的方法。
//使用注意:几个信号,参数一的方法就几个参数,每个参数对应信号发出的数据。
// 处理多个请求,都返回结果的时候,统一做处理.
RACSignal *request1 = [RACSignal createSignal:^RACDisposable *(id<RACSubscriber> subscriber) {
// 发送请求1
[subscriber sendNext:@"发送请求1"];
return nil;
}];
RACSignal *request2 = [RACSignal createSignal:^RACDisposable *(id<RACSubscriber> subscriber) {
// 发送请求2
[subscriber sendNext:@"发送请求2"];
return nil;
}];
// 使用注意:几个信号,参数一的方法就几个参数,每个参数对应信号发出的数据。
[self rac_liftSelector:@selector(updateUIWithR1:r2:) withSignalsFromArray:@[request1,request2]];
}
// 更新UI(该方法有要求,有多少个信号就要求有多少个参数,参数的内容就是发送的数据。)
- (void)updateUIWithR1:(id)data r2:(id)data1
{
NSLog(@"更新UI%@,%@",data,data1);
}
通知中心
//订阅者
[[[NSNotificationCenter defaultCenter] rac_addObserverForName:@"通知" object:nil] subscribeNext:^(NSNotification *notification) {
UILabel *label = (UILabel *)notification.object;
NSLog(@"---------------------%@--%@", NSStringFromCGRect(label.frame), label.text);
}];
//发送通知
[[NSNotificationCenter defaultCenter] postNotificationName:@"通知" object:self.timeLabel];
//这里有一个坑大家注意一下, NSNotificationCenter通知中心, !!!只能通知走过的地方! 不可以通知到未知地!!!