我正在为 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 函数中没有收到任何信息。
我的问题是:在这种情况下,使用容器,如何在两个视图控制器之间进行通信?
就像 @nwales 所说,你还没有设置委托。您应该在第一个viewController(包含viewContainer)上的prepareForSegue函数中设置委托
首先选择嵌入转场并在属性检查器中设置标识符。
然后在parentViewController中实现函数prepareForSegue,如下所示:
斯威夫特 4+:
override func prepare(for segue: UIStoryboardSegue, sender: Any?) {
if (segue.identifier == "the identifier") {
let embedVC = segue.destination as! ViewController
embedVC.delegate = self
}
}
Below:
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
}
}
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)