我正在为 iPad Pro 开发应用程序。在此应用中,containerView
用于添加额外的 views
并与之交互。
首先,我创建了一个协议(protocol):
protocol DataViewDelegate {
func setTouch(touch: Bool)
}
然后,我创建了我的第一个 View Controller
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 中的 View 。
import UIKit
class ContainerViewController: UIViewController {
var dataViewDelegate: DataViewDelegate?
override func viewDidLoad() {
super.viewDidLoad()
}
@IBAction func touchMe(sender: AnyObject) {
dataViewDelegate?. setTouch(true)
}
但由于某种原因,什么也没发生,第一个 View Controller 在 setTouch 函数中什么也没收到。
我的问题是:在这种情况下,使用容器,如何在两个 ViewsController 之间进行通信?
最佳答案
就像@nwales 所说的那样,您还没有设置委托(delegate)。您应该在第一个 viewController(包含 viewContainer)上的 prepareForSegue 函数中设置委托(delegate)
首先选择嵌入转场并在属性检查器中设置一个标识符。 然后在 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
}
}
关于swift - 在 Swift 中使用容器 View 进行委托(delegate),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34298760/