在iOS6中,我注意到新的容器视图,但不太确定如何从包含视图访问它的控制器。
场景:
我想从包含容器视图的视图控制器中访问Alert视图控制器中的标签。
它们之间有一个segue,我能用吗?
在iOS6中,我注意到新的容器视图,但不太确定如何从包含视图访问它的控制器。
场景:
我想从包含容器视图的视图控制器中访问Alert视图控制器中的标签。
它们之间有一个segue,我能用吗?
当前回答
Swift 3的更新答案,使用计算属性:
var jobSummaryViewController: JobSummaryViewController {
get {
let ctrl = childViewControllers.first(where: { $0 is JobSummaryViewController })
return ctrl as! JobSummaryViewController
}
}
这只迭代子列表,直到它到达第一个匹配。
其他回答
使用generic,你可以做一些甜蜜的事情。下面是Array的扩展:
extension Array {
func firstMatchingType<Type>() -> Type? {
return first(where: { $0 is Type }) as? Type
}
}
你可以在你的viewController中这样做:
var viewControllerInContainer: YourViewControllerClass? {
return childViewControllers.firstMatchingType()!
}
prepareForSegue方法有效,但它依赖于segue标识符魔术字符串。也许有更好的办法。
如果你知道你要找的VC的类,你可以用一个计算属性很好地做到这一点:
var camperVan: CamperVanViewController? {
return childViewControllers.flatMap({ $0 as? CamperVanViewController }).first
// This works because `flatMap` removes nils
}
这依赖于childViewControllers。虽然我同意依赖第一个类可能很脆弱,但命名您所寻找的类会使这个类看起来相当可靠。
自我。当你需要父控件时,childViewControllers更相关。例如,如果子控制器是一个表视图,你想要强制重载它或通过点击按钮或父视图控制器上的任何其他事件来改变属性,你可以通过访问ChildViewController的实例来实现,而不是通过prepareForSegue。两者都有不同的应用方式。
在视图控制器的类型上使用Swift的switch语句还有另一种方法:
override func prepare(for segue: UIStoryboardSegue, sender: Any?)
{
switch segue.destination
{
case let aViewController as AViewController:
self.aViewController = aViewController
case let bViewController as BViewController:
self.bViewController = bViewController
default:
return
}
}
你可以简单地使用self.childViewControllers.lastObject(假设你只有一个子对象,否则使用objectAtIndex:)。