我正在开发适用于iPad Pro的应用。在此应用中,containerView
用于添加其他views
并与之互动。
首先,我创建了一个协议:
protocol DataViewDelegate {
func setTouch(touch: Bool)
}
然后,我创建了我的第一个视图控制器
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中的视图。
import UIKit
class ContainerViewController: UIViewController {
var dataViewDelegate: DataViewDelegate?
override func viewDidLoad() {
super.viewDidLoad()
}
@IBAction func touchMe(sender: AnyObject) {
dataViewDelegate?. setTouch(true)
}
}
但由于某种原因,没有任何反应,第一个视图控制器在setTouch函数中什么都没有收到。
我的问题是:在这种情况下,使用容器,如何在两个ViewsControllers之间进行通信?
答案 0 :(得分:24)
就像@nwales说你还没有设置代表。您应该在第一个viewController(包含viewContainer)的prepareForSegue函数中设置委托
首先选择embed segue并在属性检查器中设置标识符。 然后在parentViewController中实现func prepareForSegue,如下所示:
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
}
}
答案 1 :(得分:6)
看起来您已定义委托,但尚未设置委托。这种情况一直发生在我身上。