大橙子网站建设,新征程启航
为企业提供网站建设、域名注册、服务器等服务
小编给大家分享一下iOS如何实现block传值,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!
创新互联是一家集网站建设,宁德企业网站建设,宁德品牌网站建设,网站定制,宁德网站建设报价,网络营销,网络优化,宁德网站推广为一体的创新建站企业,帮助传统企业提升企业形象加强企业竞争力。可充分满足这一群体相比中小企业更为丰富、高端、多元的互联网需求。同时我们时刻保持专业、时尚、前沿,时刻以成就客户成长自我,坚持不断学习、思考、沉淀、净化自己,让我们为更多的企业打造出实用型网站。首先我总结了一下block的公式:
步骤1.block 的声明 返回值类型(^block 的名字)(参数列表);
步骤2.block 实现 block的名字 = ^(参数列表)(){};
步骤3.block 的调用 block的名字();
下面是一个简单的block
// 声明 void(^blockName)(int num,NSString *string); // 实现 blockName = ^(int num,NSString *string) { NSLog(@"%d,%@",num,string); }; // 调用 blockName(520,@"phyone_"); }
由该例可以看出block的代码执行顺序和其他的代码执行顺序不一样 它是先执行声明代码 然后执行调用代码 最后才执行实现代码 由此我们利用block的回调性质 达到我们传值效果 当然这只是在一个页面的一段代码 只是说明了它具有传值的作用 下面我们来试试 多页面之间的block反向传值 由于是反向传值 所以我们创建两个ViewController (ViewController,Next_ViewController)先由ViewController跳到Next_ViewController里将里面的值反向传给ViewController
以下是代码
ViewController.m里面
- (void)viewDidLoad { [super viewDidLoad]; self.view.backgroundColor = [UIColor purpleColor]; UILabel *lable = [[UILabel alloc]initWithFrame:CGRectMake(100, 200, 200, 100)]; lable.backgroundColor = [UIColor brownColor]; [self.view addSubview:lable]; UITapGestureRecognizer *tap = [[UITapGestureRecognizer alloc]initWithTarget:self action:@selector(tap)]; [self.view addGestureRecognizer:tap]; } - (void)tap { Next_ViewController *NVC = [[Next_ViewController alloc]init]; NVC.block = ^(NSString *content){ NSLog(@"%@",content); UIButton *button = [[UIButton alloc]initWithFrame:CGRectMake(100, 200, 100, 100)]; [button setTitle:content forState:UIControlStateNormal]; button.backgroundColor = [UIColor orangeColor]; [self.view addSubview:button]; }; [self presentViewController:NVC animated:YES completion:nil]; }
Next_ViewController.h里面
//block 是分配在栈里面的用copy @property(nonatomic,copy) void(^block)(NSString *content);
Next_ViewController.m里面
{
void(^imageNameBlock_1)(NSString *imageName);
void(^lableBlock)(NSString *tontentText);
}
- (void)viewDidLoad { [super viewDidLoad]; self.view.backgroundColor = [UIColor orangeColor]; UIButton *button = [UIButton buttonWithType:UIButtonTypeCustom]; button.frame = CGRectMake(100, 200, 100, 50); [button setTitle:@"123456" forState:UIControlStateNormal]; button.backgroundColor = [UIColor redColor]; [button addTarget:self action:@selector(buttonAction:) forControlEvents:UIControlEventTouchUpInside]; [self.view addSubview:button]; } - (void)buttonAction:(UIButton *)sender { // 点击按钮 返回上一个页面 同时通过block 把这个值传到上一个页面 self.block(sender.titleLabel.text); [self dismissViewControllerAnimated:nil completion:nil]; }
另外:block 还有两个问题
1.怎么改变block里面的值
用上面的代码 在ViewController.m viewDidLoad 里面 添加代码
1.局部变量 定义一个图片名字的Block */ // 局部变量 void(^imageNameBlock)(NSString *imageName); // 如果想修改Block里面的值 需添加__block修饰 // __block UIImage *image; imageNameBlock = ^(NSString *imageName) { image = [UIImage imageNamed:imageName]; self.view.backgroundColor = [UIColor colorWithPatternImage:image]; }; imageNameBlock(@"17.jpg");
就会出现 Use of undeclared identifier 'image' 错误情况 原因是我们试图改变block里面的值 解决办法就是 添加 __block 修饰(解注释
__block UIImage *image;) 就行了
2.block的循环引用
用上面的代码 在ViewController.m viewDidLoad 里面 添加代码
// 全局变量 // block循环 引用 解决 我们用弱引用 __block __weak ViewController *VC = self; __block UIImage *image = nil; imageNameBlock_1 = ^(NSString *imageName) { image = [UIImage imageNamed:imageName]; VC.view.backgroundColor = [UIColor colorWithPatternImage:image]; }; UILabel *lable = [[UILabel alloc]initWithFrame:CGRectMake(100, 200, 200, 100)]; lable.backgroundColor = [UIColor brownColor]; [self.view addSubview:lable]; UITapGestureRecognizer *tap = [[UITapGestureRecognizer alloc]initWithTarget:self action:@selector(tap)]; [self.view addGestureRecognizer:tap];
再添加两个方法
- (void)loadData { imageNameBlock_1(@"17.jpg"); } - (void)viewWillAppear:(BOOL)animated { [self loadData]; }
以上是“iOS如何实现block传值”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注创新互联网站建设公司行业资讯频道!
另外有需要云服务器可以了解下创新互联建站www.cdcxhl.com,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。