Block传值解析
【摘要】
在子页面向父页面传值的时候,可以用代理传值。同样也可以用block块传值。
演示1
在ViewController1中有一个UILabel和一个UIButton,UILabel用来显示从子页面传过来的值,UIButton用来打开子页面。
在ViewController2中我们写block定义:
#import <U...
在子页面向父页面传值的时候,可以用代理传值。同样也可以用block块传值。
演示1
在ViewController1中有一个UILabel和一个UIButton,UILabel用来显示从子页面传过来的值,UIButton用来打开子页面。
在ViewController2页面中,返回按钮的点击代码如下:
由上面的代码我们看出block传值类似与属性传值,只不过值是一个block块代码。相当于把一个回调函数付给了子页面一个属性。
其实在代理传值的时候也类似,我们也是讲一个协议方法当做是一个属性赋值给了子页面。由此可见,Obj-C的属性可以传:对象、协议、block。
演示1
在ViewController1中有一个UILabel和一个UIButton,UILabel用来显示从子页面传过来的值,UIButton用来打开子页面。
在ViewController2中我们写block定义:
#import <UIKit/UIKit.h>
typedef void (^ReturnTextBlock)(NSString *showText); //为要声明的Block重新定义了一个名字
@interface Page1 : UIViewController
@property (nonatomic, copy) ReturnTextBlock returnTextBlock; //将一个block当做一个属性来用
@end
在ViewController2页面中,返回按钮的点击代码如下:
- (IBAction)touchCancel:(id)sender {
if (self.returnTextBlock != nil) {
self.returnTextBlock(@"2323223"); //用block回传值
}
[self dismissViewControllerAnimated:YES completion:nil];
}
在ViewController1界面中,UIButton的点击代码:
Page1 *tfVC = segue.destinationViewController;
tfVC.returnTextBlock = ^(NSString *showText) {
self.label1.text = showText;
};
由上面的代码我们看出block传值类似与属性传值,只不过值是一个block块代码。相当于把一个回调函数付给了子页面一个属性。
其实在代理传值的时候也类似,我们也是讲一个协议方法当做是一个属性赋值给了子页面。由此可见,Obj-C的属性可以传:对象、协议、block。
文章来源: zzzili.blog.csdn.net,作者:清雨小竹,版权归原作者所有,如需转载,请联系作者。
原文链接:zzzili.blog.csdn.net/article/details/51333099
【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱:
cloudbbs@huaweicloud.com
- 点赞
- 收藏
- 关注作者
评论(0)