ios - 我的便利 init 在扩展中不起作用

标签 ios swift initialization

我正在重构 UIViewController 以删除不应该出现在其中的非 UI 内容。我一直在看Andy Matuschak's great talk about this在一个示例中,他扩展了 NSPredicate 并将计算谓词应该是什么的逻辑从 View Controller 移动到 View Controller 中,并在其中设置 fetchRequest.predicate 和结果。

我正在尝试做同样的事情,但我在扩展程序的便利初始化中遇到错误:

import Foundation

extension NSPredicate { 
    convenience init(forLiftLogFilter) { // it doesn't like this line
        if let logFilter = UserDefaultsManager.sharedInstance.logFilter?.rawValue {
            filterPredicate = NSPredicate(format: "lift.liftName = [c] %@", logFilter)
        } else {
            filterPredicate = nil
        }  
    }
}

我将从“UIViewController”中调用它,如下所示:

  override func viewWillAppear(animated: Bool) {
        let filterPredicate = NSPredicate.forLiftLogFilter // thinks NSPredicate doesn't have a member named 'forLiftLogFilter'
        reloadData(filterPredicate)

    super.viewWillAppear(animated)
  }

就我而言,我不需要传递任何初始化参数,但我很确定我需要一个外部名称 forLiftLogFilter 以便我可以进行调用。 Xcode (8.0/Swift 2.3) 告诉我“未命名的参数必须使用空名称‘_’编写。我理解这个错误,但实际上我没有任何参数。它一定认为 forLiftLogFilter 是一个参数或其他东西。当然,由于这不起作用,在我调用电话的 UIViewController 中告诉我“Type NSPredicate 没有成员 'forLiftLogFilter'”。

我读了很多关于扩展、初始化器等的内容,但没有关于带有名称但没有参数的便利初始化器的答案。

任何人都可以帮助我了解我的初始化程序出了什么问题吗?

为了进行比较,这是 Andy 在他的演示中使用的代码:

extension NSPredicate {
    convenience init(forTasksWithinNumberOfDays numberOfDays: Int, ofDate: Date, calendar: NSCalendar = NSCalendar.currentCalendar()) {
    self.init(format: "dueDate = %@" argumentArray: [calendar.dateByAddingUnit(.day, value: numberOfDays, toDate: date, options: NSCalendarOptions())!] 
  }
}

他像这样从 View Controller 调用它:

override func viewDidLoad() {
    super.viewDidLoad()

    fetchRequest.predicate = NSPredicate(forTasksWithinNumberOfDays: 10, ofDate: NSDate()) 

我添加这个是为了显示我认为我需要遵循什么样的结构......

最佳答案

听起来您正在尝试创建一个返回 NSPredicate 实例的类方法。

您的扩展程序需要是这样的:

import Foundation

extension NSPredicate { 
    static func forLiftLogFilter() -> NSPredicate? {
        if let logFilter = UserDefaultsManager.sharedInstance.logFilter?.rawValue {
            return NSPredicate(format: "lift.liftName = [c] %@", logFilter)
        } else {
            return nil
        }  
    }
}

现在你可以正确调用这个类方法了:

let filterPredicate = NSPredicate.forLiftLogFilter

关于ios - 我的便利 init 在扩展中不起作用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39800022/

相关文章:

swift - 在后台或主线程中执行更新时设置 GIF 图像会阻止 UI

java - JUnit:使用构造函数而不是@Before

ios - swift 用 2 个数组填充 UItableViewCell

ios - UILabel的垂直对齐算法是什么?

ios - Jenkins 在使用 Cocoapods 构建 Xcode 项目时返回 "unknown error -1=ffffffffffffffff"

ios - 尝试设置弹出窗口时 UITextView 为零

swift - 绑定(bind)的 property/$property 语法是什么?

c++ - 如何定义静态 boost 共享指针?

C# 对象初始化选项

ios - 如何在它继续之前添加延迟