我如何在Swift中获得对AppDelegate的引用?
最后,我想使用引用来访问托管对象上下文。
我如何在Swift中获得对AppDelegate的引用?
最后,我想使用引用来访问托管对象上下文。
当前回答
我在Swift 2.3中使用这个功能。
1. 在AppDelegate类中
static let sharedInstance: AppDelegate = UIApplication.sharedApplication().delegate as! AppDelegate
2. 调用AppDelegate
let appDelegate = AppDelegate.sharedInstance
其他回答
Swift < 3
在AppDelegate类中为ex创建一个方法
func sharedInstance() -> AppDelegate{
return UIApplication.sharedApplication().delegate as! AppDelegate
}
叫它"前任"吧
let appDelegate : AppDelegate = AppDelegate().sharedInstance()
Swift >= 3.0
func sharedInstance() -> AppDelegate{
return UIApplication.shared.delegate as! AppDelegate
}
斯威夫特4.2
在Swift中,很容易在你的VC中访问
extension UIViewController {
var appDelegate: AppDelegate {
return UIApplication.shared.delegate as! AppDelegate
}
}
在Xcode 6.2中,这也是可行的
let appDelegate = UIApplication.sharedApplication().delegate! as AppDelegate
let aVariable = appDelegate.someVariable
另一个解决方案是正确的,因为它会让你引用应用程序的委托,但这将不允许你访问任何方法或变量添加你的UIApplication的子类,如你的管理对象上下文。要解决这个问题,只需向下转换为“AppDelegate”或任何你的UIApplication子类碰巧被调用的东西。在Swift 3,4和5中,这样做:
let appDelegate = UIApplication.shared.delegate as! AppDelegate
let aVariable = appDelegate.someVariable
从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
}
}