swift – 如何声明一个具有类型并实现协议的变量?

前端之家收集整理的这篇文章主要介绍了swift – 如何声明一个具有类型并实现协议的变量?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我的应用程序有一个详细视图控制器的协议,说明他们必须有一个viewmodel属性
  1. protocol DetailViewController: class {
  2. var viewmodel: viewmodel? {get set}
  3. }

我也有几个不同的类实现协议:

  1. class FormViewController: UITableViewController,DetailViewController {
  2. // ...
  3. }
  4.  
  5. class MapViewController: UIViewController,DetailViewController {
  6. // ...
  7. }

我的主视图控制器需要一个属性,可以设置为任何UIViewController子类实现DetailViewController协议。

遗憾的是,我找不到任何文档如何做到这一点。在Objective-C中这将是微不足道的:

  1. @property (strong,nonatomic) UIViewController<DetailViewController>;

看来Swift中没有任何可用的语法来做到这一点。最近我来的是在我的类定义中声明一个泛型:

  1. class MasterViewController<T where T:UIViewController,T:DetailViewController>: UITableViewController {
  2. var detailViewController: T?
  3. // ...
  4. }

但是,然后我得到一个错误说“类’MasterViewController’不实现其超类的必需成员”

这似乎应该像Swift中一样容易做,因为它是在Objective-C,但我找不到任何地方,任何地方建议我可以如何去。

我想你可以通过添加一个(空)扩展到UIViewController,然后指定你的detailViewController属性使用空扩展和你的DetailViewController的组合协议。喜欢这个:
  1. protocol UIViewControllerInject {}
  2. extension UIViewController : UIViewControllerInject {}

现在UIViewController的所有子类都满足协议UIViewControllerInject。然后,简单地:

  1. typealias DetailViewControllerComposed = protocol<DetailViewController,UIViewControllerInject>
  2.  
  3. class MasterViewController : UITableViewController {
  4. var detailViewController : DetailViewControllerComposed?
  5. // ...
  6. }

但是,这不是特别“自然”。

===编辑,加法===

实际上,如果你使用我建议的UIViewControllerInject定义你的DetailViewController,你可以使它更好一些。像这样:

  1. protocol UIViewControllerInject {}
  2. extension UIViewController : UIViewControllerInject {}
  3.  
  4. protocol DetailViewController : UIViewControllerInject { /* ... */ }

现在你不需要显式编写一些东西(我的DetailViewControllerComposed),并可以使用DetailViewController?作为detailViewController的类型。

猜你在找的Swift相关文章