RAC常见用法
代替代理
- 使用RAC代替代理时,rac_signalForSelecto:fromProtocol:这个代替代理的方法使用时,切记要将self设为代理这句话放在订阅代理信号的后面写,否则会无法执行12345678910111213141516//这里订阅收到的是一个x,当一个页面存在多个tableview时,我们可以对x进行判断看是哪个tableview[[self rac_signalForSelector:@selector(tableView:didSelectRowAtIndexPath:) fromProtocol:@protocol(UITableViewDelegate) ] subscribeNext:^(RACTuple * x) {NSLog(@"点击了");NSLog(@"%@,%@",x.first,x.second);}];//这样子不带协议是无法代替代理的,虽然能达到效果,这个方法表示某个selector被调用时执行一段代码.带有协议参数的表示该selector实现了某个协议,所以可以用它来实现Delegate。// [[self rac_signalForSelector:@selector(tableView:didSelectRowAtIndexPath:)] subscribeNext:^(RACTuple* x) {// NSLog(@"%@",[x class]);// NSLog(@"%@",x);// }];//这里是个坑,必须将代理最后设置,否则信号是无法订阅到的//雷纯峰大大是这样子解释的:在设置代理的时候,系统会缓存这个代理对象实现了哪些代码方法//如果将代理放在订阅信号前设置,那么当控制器成为代理时是无法缓存这个代理对象实现了哪些代码方法的tableview.delegate = self;
KVO
- 使用RAC代替KVO很简单,一句话就可以搞定,而且相比传统的KVO,不仅代码不用放在一起写美观了很多,同时还能达到高聚合低耦合的目标。1234//代替KVO[RACObserve(scrollView, contentOffset) subscribeNext:^(id x) {NSLog(@"%@",x);}];
监听事件
|
|
通知
- 这里是有个坑的,单纯的写完订阅通知的信号会发现每次都会执行,而且叠加次数会增加,效果如图所示,所以我们要想办法把通知订阅的信号给释放掉,所以用到了takeUntil这个方法。1234//takeUntil会接收一个signal,当signal触发后会把之前的信号释放掉[[[[NSNotificationCenter defaultCenter] rac_addObserverForName:UIKeyboardDidShowNotification object:nil] takeUntil:self.rac_willDeallocSignal] subscribeNext:^(id x) {NSLog(@"键盘弹出");}];
定时器
延时执行
1234//五秒后执行一次[[RACScheduler mainThreadScheduler]afterDelay:5 schedule:^{NSLog(@"五秒后执行一次");}];定时执行
12345//每隔两秒执行一次//这里要加takeUntil条件限制一下否则当控制器pop后依旧会执行[[[RACSignal interval:2 onScheduler:[RACScheduler mainThreadScheduler]] takeUntil:self.rac_willDeallocSignal ] subscribeNext:^(id x) {NSLog(@"每两秒执行一次");}];
监听文本框的文字改变
|
|
处理多个请求,都返回结果的时候,统一做处理
|
|