响应链错误
Responder chain error
我想将这种 Objective-C 代码翻译成 Swift:
- (UINavigationController *)targetNaviCtrl{
if(!_targetNaviCtrl){
UIResponder *target = self.nextResponder;
do {
target = target.nextResponder;
} while (![target isKindOfClass:UINavigationController.self] && target != nil);
_targetNaviCtrl = (UINavigationController *)target;
}
return _targetNaviCtrl;
}
// by iterate its next responder, so I can get access the target viewController to do something.
// This is often used across several hierarchies.
// A root B, B push C , C push D. I use A in D viewController.
我遇到了一些麻烦。
Declaration
var next: UIResponder? { get }
Return Value
The next object in the responder chain or nil if this is the last object in the chain.
我想在右边访问左边的tarBarControllerviewController。
classViewControllerEightLayer
//右边viewController.
class ViewControllerEightLayer: UIViewController {
override var next: UIResponder?{
get{
return super.next
}
}// the right viewController.
override func viewWillAppear(_ animated: Bool) {
super.viewWillAppear(animated)
var nextResponder = self.next! // Here I call it
}
这里是我调用的,这里是错误信息:
Thread 1: Fatal error: Unexpectedly found nil while unwrapping an Optional value
class LayerTableVC
// UITableViewController 居中一点.
class LayerTableVC: UITableViewController {
override var next: UIResponder?{
get{
return super.next
}
}// the center a little right UITableViewController.
class LayerNavigationVC
// 中间稍微偏左的UINavigationController.
class LayerNavigationVC: UINavigationController {
override var next: UIResponder?{
get{
return super.next
}
}// the center a little left UINavigationController.
class MainTabBarVC
//左边的tarBarController
class MainTabBarVC: UINavigationController {
override var next: UIResponder?{
get{
return self
}
}// the left tarBarController
我不知道这样怎么解决。有什么建议吗?
也许有帮助,
self.next?.target(forAction: <#T##Selector#>, withSender: <#T##Any?#>)
似乎有线。
我是按代码做的,
let tabBarViewController = UIApplication.shared.keyWindow!.rootViewController as! UITabBarController
而我想知道响应者链解决方案
PS:
挖掘响应者链的目的是出于好奇。
它发生了,我认为它不会发生。
所以我想知道为什么。
我想逆向工程。
PPS:
我的意图是控制工具栏的隐藏和显示。未提供来自至
的数据
extension ViewControllerEightLayer: UITextFieldDelegate{
func textFieldShouldReturn(_ textField: UITextField) -> Bool {
if textField.text == "1" {
tabBarViewController.tabBar.isHidden = false
}
else{
tabBarViewController.tabBar.isHidden = true
}
return true
}
这是个人实验项目,不属于我公司。
您似乎在询问如何沿着响应链向上走。方法如下。
func showResponderChain(_ r: UIResponder) {
var r : UIResponder! = r
repeat { print(r, "\n"); r = r.next } while r != nil
}
我想将这种 Objective-C 代码翻译成 Swift:
- (UINavigationController *)targetNaviCtrl{
if(!_targetNaviCtrl){
UIResponder *target = self.nextResponder;
do {
target = target.nextResponder;
} while (![target isKindOfClass:UINavigationController.self] && target != nil);
_targetNaviCtrl = (UINavigationController *)target;
}
return _targetNaviCtrl;
}
// by iterate its next responder, so I can get access the target viewController to do something.
// This is often used across several hierarchies.
// A root B, B push C , C push D. I use A in D viewController.
我遇到了一些麻烦。
Declaration
var next: UIResponder? { get }
Return Value
The next object in the responder chain or nil if this is the last object in the chain.
我想在右边访问左边的tarBarControllerviewController。
classViewControllerEightLayer
//右边viewController.
class ViewControllerEightLayer: UIViewController {
override var next: UIResponder?{
get{
return super.next
}
}// the right viewController.
override func viewWillAppear(_ animated: Bool) {
super.viewWillAppear(animated)
var nextResponder = self.next! // Here I call it
}
这里是我调用的,这里是错误信息:
Thread 1: Fatal error: Unexpectedly found nil while unwrapping an Optional value
class LayerTableVC
// UITableViewController 居中一点.
class LayerTableVC: UITableViewController {
override var next: UIResponder?{
get{
return super.next
}
}// the center a little right UITableViewController.
class LayerNavigationVC
// 中间稍微偏左的UINavigationController.
class LayerNavigationVC: UINavigationController {
override var next: UIResponder?{
get{
return super.next
}
}// the center a little left UINavigationController.
class MainTabBarVC
//左边的tarBarController
class MainTabBarVC: UINavigationController {
override var next: UIResponder?{
get{
return self
}
}// the left tarBarController
我不知道这样怎么解决。有什么建议吗?
也许有帮助,
self.next?.target(forAction: <#T##Selector#>, withSender: <#T##Any?#>)
似乎有线。
我是按代码做的,
let tabBarViewController = UIApplication.shared.keyWindow!.rootViewController as! UITabBarController
而我想知道响应者链解决方案
PS:
挖掘响应者链的目的是出于好奇。
它发生了,我认为它不会发生。
所以我想知道为什么。
我想逆向工程。
PPS:
我的意图是控制工具栏的隐藏和显示。未提供来自至
的数据 extension ViewControllerEightLayer: UITextFieldDelegate{
func textFieldShouldReturn(_ textField: UITextField) -> Bool {
if textField.text == "1" {
tabBarViewController.tabBar.isHidden = false
}
else{
tabBarViewController.tabBar.isHidden = true
}
return true
}
这是个人实验项目,不属于我公司。
您似乎在询问如何沿着响应链向上走。方法如下。
func showResponderChain(_ r: UIResponder) {
var r : UIResponder! = r
repeat { print(r, "\n"); r = r.next } while r != nil
}