IOS-block实现页面之间的传值

利用Block实现两个页面之间的传值,假设有两个控制器control1 和control2,control1上有一个label和一个button,点击button跳转到control2,control2上有一个button和一个textField,点击control2上的button回到control1,并将textField上输入的文字显示在control1的label上:

//---------------------control2.h
#import 

typedef void(^ChangeTextBlock) (NSString *text);

@interface ModalViewController : UIViewController

//定义一个block
@property (nonatomic, copy) ChangeTextBlock block;

@end


//----------------------control2.m
- (void) backAction: (UIButton *) button {
    
    //1) 取值
    UITextField *textField = (UITextField *)[self.view viewWithTag:2000];
    
    //2) 修改值 -----》 调用block来修改值
    if (self.block != nil) {
        self.block(textField.text);
    }
    
    //3) 关闭模态视图
    [self dismissViewControllerAnimated:YES completion:nil];
 
}

//---------------------control1.m
- (void) buttonAction: (UIButton *) button {
    
    //1. 实现block,使用__weak的原因:是防止内存的泄露
    __weak Controller1 *control1 = self;
    
    //2. block的初始化
    _modalViewController.block = ^(NSString *text) {
        //如果不用__weak的对象,那么这里会提示一个警告 ------> 内存的
        UILabel *label = (UILabel *) [control1.view viewWithTag:1000];
        label.text = text;
    };
    
    //3. 弹窗模式
    _modalViewController.modalTransitionStyle = UIModalTransitionStyleCoverVertical;

    //4. 模态视图
    [self presentViewController:_modalViewController animated:YES completion:nil];
    
}

这里我只把实现传值部分的代码附上,我们可以看到在control1的button实现的方法中,定义了一个用weak修饰的控制器control1指向自己,如果不用weak的对象,下面的block的实现会出现警告,提示内存泄漏:

Capturing self strongly in this block is likely to lead to retain cycle,retain cycle,简单来说就是甲引用乙,乙又引用甲,双方都在等对方释放,就形成了一个圈,出现内存错误。



你可能感兴趣的:(IOS开发)