在Swift中使用容器视图进行委托

问题描述 投票:9回答:2

我正在为iPad Pro开发应用程序。在此应用中,containerView用于添加其他views并与其进行交互。

首先,我创建了一个协议:

protocol DataViewDelegate {
    func setTouch(touch: Bool)
}

然后,我创建了我的第一个视图控制器

enter image description here

import UIKit

class ViewController: UIViewController, DataViewDelegate {

    @IBOutlet var container: UIView!
    @IBOutlet var labelText: UILabel!

    override func viewDidLoad() {
        super.viewDidLoad()
    }

    func setTouch(touch: Bool) {
        if touch == true {
            labelText.text = "Touch!"
        }
    }

}

最后,我创建了一个将嵌入到containerView中的视图。

enter image description here

import UIKit

class ContainerViewController: UIViewController {

    var dataViewDelegate: DataViewDelegate?

    override func viewDidLoad() {
        super.viewDidLoad()
    }

    @IBAction func touchMe(sender: AnyObject) {
        dataViewDelegate?. setTouch(true)
    }

}

但是由于某种原因,什么也没发生,第一个视图控制器在setTouch函数中什么也没收到。

我的问题是:在这种情况下,使用容器,如何在两个ViewsController之间进行通信?

swift uiviewcontroller swift2 uicontainerview swift2.1
2个回答
6
投票

看起来您定义了委托,但尚未设置委托。这一直在我身上发生。


24
投票

像@nwales一样,您尚未设置代表。您应该在第一个viewController(包含viewContainer)的prepareForSegue函数中设置委托。

首先选择嵌入的序列,然后在属性检查器中设置标识符。然后在parentViewController中实现如下函数func prepareForSegue:

Swift 4+:

override func prepare(for segue: UIStoryboardSegue, sender: Any?) {
        if (segue.identifier == "the identifier") {
            let embedVC = segue.destination as! ViewController
            embedVC.delegate = self
        }
    }

以下:

override func prepareForSegue(segue: UIStoryboardSegue, sender: AnyObject?) {
    // Get the new view controller using segue.destinationViewController.
    // Pass the selected object to the new view controller.
    if (segue.identifier == "the identifier") {
        let embedVC = segue.destinationViewController as! ContainerViewController
        embedVC.dataViewDelegate = self
    }
}
© www.soinside.com 2019 - 2024. All rights reserved.