我如何在Swift中获得对AppDelegate的引用?

最后,我想使用引用来访问托管对象上下文。


当前回答

从iOS 12.2和Swift 5.0开始,AppDelegate不能被识别。UIApplicationDelegate。因此,任何涉及AppDelegate的答案都不再正确。下面的答案是正确的,并避免了强制展开,一些开发人员认为这是一种代码气味:

import UIKit

extension UIViewController {
  var appDelegate: UIApplicationDelegate {
    guard let appDelegate = UIApplication.shared.delegate else {
      fatalError("Could not determine appDelegate.")
    }
    return appDelegate
  }
}

其他回答

下面是一个UIApplicationDelegate的扩展,它避免了硬编码AppDelegate类名:

extension UIApplicationDelegate {

    static var shared: Self {    
        return UIApplication.shared.delegate! as! Self
    }
}

// use like this:
let appDelegate = MyAppDelegate.shared // will be of type MyAppDelegate

从iOS 12.2和Swift 5.0开始,AppDelegate不能被识别。UIApplicationDelegate。因此,任何涉及AppDelegate的答案都不再正确。下面的答案是正确的,并避免了强制展开,一些开发人员认为这是一种代码气味:

import UIKit

extension UIViewController {
  var appDelegate: UIApplicationDelegate {
    guard let appDelegate = UIApplication.shared.delegate else {
      fatalError("Could not determine appDelegate.")
    }
    return appDelegate
  }
}

在Swift 3.0中,你可以通过

let appDelegate = UIApplication.shared.delegate as! AppDelegate

我在Swift 2.3中使用这个功能。

1. 在AppDelegate类中

static let sharedInstance: AppDelegate = UIApplication.sharedApplication().delegate as! AppDelegate

2. 调用AppDelegate

let appDelegate = AppDelegate.sharedInstance

以下是Swift 5的版本:

let delegate = UIApplication.shared.delegate as? AppDelegate

并访问管理对象上下文:

    if let delegate = UIApplication.shared.delegate as? AppDelegate {

        let moc = delegate.managedObjectContext
        
        // your code here
        
    }

或者,用guard:

    guard let delegate = UIApplication.shared.delegate as? AppDelegate  else {
        return
    }

    let moc = delegate.managedObjectContext
        
    // your code here