Swift 闭包传值

实现例子由两个界面组成html

A  B 两个视图
A - > B 使用属性传值
B - > A 使用闭包进行反向回调传值闭包

Swift 使用闭包传值的原理,与OC 中使用代码块(block)传值原理,基本相似ide

按步骤能够以下理解:
一、定义闭包。
二、闭包赋值(传送)
三、闭包调用。orm

想对于当前界面上执行某个操做,就在当前界面上定义,
好比:我想经过 B 界面回调 给 A 界面上的label赋值,赋值操做是在 A 界面上执行的、那么闭包就应该定义在 A 界面上。既然定义在 A ,那么 B 界面就是调用闭包的地方。找准实现者,跟调用者,而后在调用者界面定义属性用于接收闭包便可;htm

实现代码:get

import UIKit

class ViewController: UIViewController {
    
    // 懒加载添加 btn
    lazy var btn:UIButton = {
        let button = UIButton(frame: CGRectMake(100, 200, 100, 30))
        button.backgroundColor = UIColor.redColor()
        button.addTarget(self, action: "btnAction:", forControlEvents: UIControlEvents.TouchUpInside)
        button.setTitle("点击跳转页面", forState: UIControlState.Normal)
        return button
    } ()it

  // 懒加载方法添加 label
    lazy var label:UILabel = {
        let lab = UILabel(frame: CGRectMake(100, 100, 100, 30))
        lab.backgroundColor = UIColor.yellowColor()
        return lab
    } ()
    
    // btn 实现方法
    func btnAction(btn:UIButton) {
        let secVC = SecViewController()io

// 属性传值 赋值
        secVC.str = label.text
        
        // 接收传过来的值
        secVC.sendValue = {
            (str: String)-> () in
            self.label.text = str
        }
        // present 到 B 界面
        self.presentViewController(secVC, animated: true, completion: nil)
    }
   
    override func viewDidLoad() {
        super.viewDidLoad()
        
        view.addSubview(btn)
        
        view.addSubview(label)
        
    }
}class

 

import UIKit

class SecViewController: UIViewController {import

 // 属性传值 定义变量
    var str:String?


    // 变量:类型  此处类型是个闭包
    var sendValue:((str:String)->())?
    
    // 懒加载添加 textfield
    lazy var textField:UITextField = {
        let tf = UITextField(frame: CGRectMake(100, 100, 100, 30)) 

 // 属性传值 取值        tf.text = self.str               tf.backgroundColor = UIColor.yellowColor()        return tf    } ()        // 懒加载添加 btn    lazy var button:UIButton = {        let btn = UIButton(frame: CGRectMake(100, 200, 100, 30))        btn.setTitle("back", forState: UIControlState.Normal)        btn.addTarget(self, action: "back", forControlEvents: UIControlEvents.TouchUpInside)        return btn    } ()        // btn实现方法    func back() {        // 调用        if sendValue != nil {           sendValue!(str: textField.text!)         }                self.dismissViewControllerAnimated(true, completion: nil)    }    override func viewDidLoad() {        super.viewDidLoad()        view.addSubview(textField)                view.addSubview(button)    }}