Jam*_*mes 9 uiviewcontroller uicontainerview swift swift2 swift2.1
我正在为iPad Pro开发一款应用程序.在这个应用程序中,containerView用于添加其他内容views并与它们进行交互.
首先,我创建了一个协议:
protocol DataViewDelegate {
func setTouch(touch: Bool)
}
Run Code Online (Sandbox Code Playgroud)
然后,我创建了我的第一个视图控制器
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!"
}
}
Run Code Online (Sandbox Code Playgroud)
}
最后,我创建了一个嵌入在containerView中的视图.
import UIKit
class ContainerViewController: UIViewController {
var dataViewDelegate: DataViewDelegate?
override func viewDidLoad() {
super.viewDidLoad()
}
@IBAction func touchMe(sender: AnyObject) {
dataViewDelegate?. setTouch(true)
}
Run Code Online (Sandbox Code Playgroud)
}
但由于某种原因,没有任何反应,第一个视图控制器在setTouch函数中什么都没有收到.
我的问题是:在这种情况下,使用容器,如何在两个ViewsControllers之间进行通信?
LHI*_*OUI 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
}
}
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
4157 次 |
| 最近记录: |