QVO 单例 w=10=sh?

KVO on singleton property?

大家好,我正在尝试在 Singleton class 中的一个字符串属性上实现 KVO。我目前 运行 在尝试添加观察者时遇到了一些错误,希望有人能告诉我我做错了什么。 下面显示了我的单例 class.

class User: NSObject {

    static let currentUser = User()
    private override init() {}

    var pictureString: String?
}

在单独的 ViewController 的 viewDidLoad 中,我尝试像这样将观察者添加到 pictureString 变量。

    self.addObserver(self, forKeyPath: #keyPath(User.currentUser.pictureString), options: [.old, .new, .initial], context: nil)

我现在正在处理的问题是它声明 currentUser 不符合 KVC。我目前遇到以下错误。

    addObserver: forKeyPath:@"currentUser.pictureString" options:7 context:0x0] was sent to an object that is not KVC-compliant for the "currentUser" property.'

如有任何帮助,我将不胜感激。

参见

As for now, Swift cannot have observable class properties.

如果你真的想使用单例,你可以将它转换为具有普通 属性 的非静态单例,然后也可以是 KVO ......像这样:

class UserManager: NSObject {
  private override init() {}
  static var instance = UserManager()
  var currentUser = User()
}

class User: NSObject {
  dynamic var pictureString: String?
}

注意变量声明中的 dynamic 关键字——这是使 KVO 在 Swift 中工作所必需的(here 解释了动态调度)。

然后在您的 VC 的 viewDidLoad 中,您可以通过以下方式注册更改:

UserManager.instance.addObserver(self, forKeyPath: #keyPath(UserManager.currentUser.pictureString), options: [.old, .new, .initial], context: nil)
class Viewcontroller: UIViewController {

  let user = User.currentUser

  override viewDidLoad() {
    super.viewDidLoad()
    addObserver(self, forKeyPath: #keyPath(user.pictureString), options: [.old, .new], context: nil)
  }
}

您可以声明您的单例并将其用于#keyPath。否则,您将引发异常。