当前位置:  开发笔记 > IOS > 正文

如何覆盖init方法并在swift中返回一个storyboard实例

如何解决《如何覆盖init方法并在swift中返回一个storyboard实例》经验,为你挑选了1个好方法。

在Objective-C中,我可以轻松地使用以下代码:

- (instancetype)init {
    UIStoryboard *sb = [UIStoryboard storyboardWithName:@"Main" bundle:nil];
    self = [sb instantiateViewControllerWithIdentifier:@"WMViewController"];
    return self;
}

如何使用Swift实现这一点?我知道这样做很奇怪,但由于某些原因,我必须初始化一个viewController,如下所示:

let vcClass = WMTableViewController.self
// ...
let vc = vcClass.init()

因此,为了支持storybord / xib,如果可以覆盖init方法并返回另一个实例将很容易.

这是我正在做的工作:

我正在尝试将我的小lib(WMPageController)转换为Swift(WMPageController-Swift),然后我被困在这里.如果你有另一个建议或解决方案来处理它我会很高兴.

非常感谢,如果你想帮助我.



1> Luca Angelet..:

好问题.我过去试图解决同样的问题.

具体的解决方案

首先,您可以使用类方法

class WMViewController: UIViewController {
    class func loadFromStoryboard() -> WMViewController? {
        return UIStoryboard(name: "main", bundle: nil).instantiateViewControllerWithIdentifier("WMViewController") as? WMViewController
    }
}

并像这样使用它

let controller = WMViewController.loadFromStoryboard()

一般解决方案

但是,将loadFromStoryboard方法添加到要使其"可加载"的每个ViewController是一种不好的做法.所以我们可以在协议扩展中移动该代码.

protocol StoryboardLoadable { }
extension StoryboardLoadable where Self:UIViewController {
    private static var identifier: String { return "\(Self.self)" }
    static func loadFromStoryboard() -> Self? {
        return UIStoryboard(name: "main", bundle: nil).instantiateViewControllerWithIdentifier(identifier) as? Self
    }
}

现在,您只需将此loadFromStoryboard方法添加到自定义视图控制器即可

extension WMViewController: StoryboardLoadable {}

而已.现在您可以加载视图控制器编写

let controller = WMViewController.loadFromStoryboard()

推荐阅读
wurtjq
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有