
- (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),然后我被困在这里.如果你有另一个建议或解决方案来处理它,我会很高兴.
非常感谢,如果你想帮助我.
解决方法 好问题.我过去试图解决同样的问题.具体的解决方案
首先,您可以使用类方法
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()总结
以上是内存溢出为你收集整理的ios – 如何覆盖init方法并在swift中返回storyboard实例全部内容,希望文章能够帮你解决ios – 如何覆盖init方法并在swift中返回storyboard实例所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)