1

我想将这种 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.

我遇到了一些麻烦。

代码仓库


苹果文档:下一个

宣言

var next: UIResponder?{ 得到 }

返回值

响应者链中的下一个对象,如果这是链中的最后一个对象,则为 nil。

距离

我想在右 viewController 中访问左 tarBarController。

类 ViewControllerEightLayer

// 正确的 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
}

我在这里调用它,这是错误信息:

线程 1:致命错误:在展开可选值时意外发现 nil

类LayerTableVC

// 中心稍微向右 UITableViewController.

 class LayerTableVC: UITableViewController {
    override var next: UIResponder?{
        get{
           return super.next
        }
  }// the center a little right UITableViewController.

类LayerNavigationVC

// 中心向左一点 UINavigationController.

 class LayerNavigationVC: UINavigationController {
    override var next: UIResponder?{
        get{
           return super.next
        }
  }// the center a little left UINavigationController.

类 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:

挖掘响应者链的目的是好奇心。

它发生了,我不认为它会发生。

所以我想知道为什么。

我想进行逆向工程。


PP:

我的意图是控制工具栏的隐藏和显示。不提供数据

 extension ViewControllerEightLayer: UITextFieldDelegate{
    func textFieldShouldReturn(_ textField: UITextField) -> Bool {
        if textField.text == "1" {
            tabBarViewController.tabBar.isHidden = false
         }
         else{
             tabBarViewController.tabBar.isHidden = true
         }
         return true
   }

这是一个个人实验项目,不是我公司的。

4

1 回答 1

2

您似乎在询问如何走上响应者链。就是这样。

func showResponderChain(_ r: UIResponder) {
    var r : UIResponder! = r
    repeat { print(r, "\n"); r = r.next } while r != nil
}
于 2018-04-13T02:42:59.777 回答