获取视图控制器引用

Obtaining a View Controller Reference

我看了很多问题和答案都没有这个问题。有些是为了目标 C。有些是为了 iOS。那些接近我需要的没有工作。

我已经制定了授权协议。它不起作用。问题是未设置委托变量。我需要对活动控制器的引用。

委托人

protocol SwitchTabDelegate: class {
  func selectTab(tab: Int)
}

class ViewController: NSViewController {

  weak var delegate: SwitchTabDelegate?

  override func viewDidLoad() {
    super.viewDidLoad()
  }

  @IBAction func selectCompositions(_ sender: NSButton) {

    if let delegate = self.delegate {
      delegate.selectTab(tab: 2)
    }
    else {
      print("self.delegate is nil")
    }
    print("delegate called")
  }
}

委托人

class TabViewController: NSTabViewController, SwitchTabDelegate {

  var viewController : ViewController?;

  override func viewDidLoad() {
    super.viewDidLoad()
    //viewController = storyboard?.instantiateController(withIdentifier: "viewController") as? ViewController
   // viewController?.delegate = self
  // print(viewController)
  }

  func selectTab(tab: Int) {
    print("In the delegate")
    switchToDataTab()
  }

  func switchToDataTab() {
    Timer.scheduledTimer(timeInterval: 0.2, target: self,
        selector: #selector(switchToDataTabCont),
        userInfo: nil, repeats: false)
  }

  func switchToDataTabCont(){
    self.selectedTabViewItemIndex = 2
  }
}

委托人是主要的NSViewContoller。在故事板上,它包含两个按钮和一个容器视图控制器。嵌入在容器视图控制器中的是 TabViewController,委托者。您可以在受托人中看到我试图获得参考的地方。它确实获得了一个引用,大概是对新实例化的实例的引用。我需要对应用程序启动时启动的原始视图控制器的引用。

回答

我在委托人中添加了以下代码:

override func prepare(for segue: NSStoryboardSegue, sender: Any?) {

  let controller = segue.destinationController as! TabViewController
  self.delegate = controller as SwitchTabDelegate
 }

按照设计模式,这不是它应有的工作方式。委托人不应该知道被委托人。我在这个问题上花了太多时间,所以要进行黑客攻击。

使用故事板时,您希望在创建子项时 "push" 引用它们而不是从上游控制器中拉出它们。这就是 -prepareForSegue:sender: 的用途。