OC 3大回调模式使用总结(三)block回调
block 又称 代码块,闭包等
是一个匿名的函数,它能够当做一个对象来使用,仅仅只是这个对象非常特殊,是一段代码,他能够保存你写的一段预备性质代码,待某个不确定的事件发生时再调用;事件发生时,它可能会给你传递一些状态參数(回传),来方便你的使用
block经常使用类型(能够看做一个匿名函数的类型):
typedef int(^Add)(int,int);//定义一个block类型 typedef void(^Logg)(NSString *);//有一个參数,可是没有返回值的 typedef void(^FFF)(void);//没有參数也没有返回值
block外部变量(能够被block引用)
NSString *s1 = @"你好外部变量1"; __block int ccc = 2;//__block修饰的变量能够在代码块内部改变,否则是不能够改变的
使用上述的3中block类型,定义3个block变量,能够当做函数使用
Add aa = ^(int a,int b)//定义一个block变量,变量的值是一段代码 { NSLog(@"s1 = %@",s1);//捕获外部变量 NSLog(@"ccc = %d",ccc); ccc++;//默认外部变量是仅仅读的,除非加上__block return a+b; }; NSLog(@"%d",aa(1,2));//调用aa 代码块
Logg lo = ^(NSString *str) { NSLog(@"打印字符串!%@",str); }; lo(@"没有返回值的block測试!");
FFF f = ^(){NSLog(@"s1 = %@",s1);ccc++;}; f();//没有參数的block使用
block的使用场景:
1.网络请求的回调 2.封装自己定义的组件 3.反向传值 4.其它
block的特点:block中能够捕获其它对象的属性和方法,作用域非常大;我们在(3)中进行说明
(1)假设你使用过AFNetworking或者ASIHttpRequest你不会对第1种使用场景产生不论什么疑问,对于网络请求的成功或者失败的操作,都是须要时间的,都是异步的操作;所以,你须要提前写好操作代码,待某个状态到达的时候会则自己主动调用这段代码;比如你提前写好网络请求成功之后的block块,该block可能包括一些參数,这些參数是请求成功或者失败之后的參数,能够让你对这些參数进行处理
比如AFNetworking的使用,对于成功或者失败之后的处理都是使用了block
成功之后的运行的block
success:^(AFHTTPRequestOperation *operation, id responseObject) {}
失败之后运行的block
failure:^(AFHTTPRequestOperation *operation, NSError *error) {//失败之后的block块 }
/*
* 开启一个异步网络请求,成功或失败后,会运行你写的代码
*/
AFHTTPRequestOperation *op = [self.afMannager GET:url parameters:dict success:^(AFHTTPRequestOperation *operation, id responseObject) {//成功后其返回成功的状态參数,供你使用 NSArray *arr = [NSJSONSerialization JSONObjectWithData:responseObject options:NSJSONReadingAllowFragments error:nil];//JSON解析 } failure:^(AFHTTPRequestOperation *operation, NSError *error) { //失败之后的block块,处理失败操作 }]; op.responseSerializer = [AFHTTPResponseSerializer serializer]; [op start];//開始请求
(2)你也能够自己封装一些组件,然后给外界一些处理事件的接口,这个时候你也能够使用block回调模式;仅仅须要外界传入他的处理代码,那么这个组件在达到这个状态的时候,就会自己主动调用你写的代码.
(3)反向传值,比如两个界面A,B;点击A界面上的button跳到B 编辑界面,B编辑界面在返回时须要传给A界面一些字符串,这个过程是反向传值;这个时候我们能够使用block模式来实现.
在A类中,我们能够预设B界面返回时的代码,即使用block,注意到在B返回时,这个事件须要汇报B自身的状态,即B要汇报一些实用的參数(字符串),那么block须要有一个參数,该參数就是B返回时传来的
代码演示样例:
A中给B预设返回时的代码块,也就是说B 的代码块获得了A的属性和方法,B在状态改变时会调用该block改变A A.m [B setTapSaveBlock:^(NSString *str) { [self.btn_Hobby setTitle:str forState:UIControlStateNormal]; }]; [self.navigationController pushViewController:B animated:YES];//从A 推到B 界面
描写叙述: A推到B界面之前,首先给B设置返回时的代码,该代码用于返回B的參数str,该代码用于调用A的某些属性或者方法
效果:在B的block控制了A的某些属性和方法,且B能汇报自己的状态给A(也就是block的參数);A的属性拿到B的參数后可能将该參数用于配置A,从而达到了反向传值的目的,把B的值传给了A
效果演示:
A界面:
点击我的昵称,签名,兴趣爱好会推到一个新的界面B:
B 界面:
在B编辑完毕,之后须要把最新的文本,回传给A; 也就是关闭 B界面时,A上须要显示B传给A的 字符串,这个过程就包括由B到A的反向传值过程
很多其它相关文章:http://blog.csdn.net/yangbingbinga/article/category/2437601