2014-10-01 43 views
5

我试图在我写的Swift中的iOS应用程序中采用ReactiveCocoa。不幸的是,它看起来像rac_valuesForKeyPath不能按预期工作。 这里的例子:ReactiveCocoa rac_valuesForKeyPath在Swift中不起作用

class Source: NSObject { 
    var observable: String = "<Original>" 

    override init() { 
     super.init() 

     dispatch_after(dispatch_time(DISPATCH_TIME_NOW, Int64(1 * NSEC_PER_SEC)), dispatch_get_main_queue(), {() -> Void in 
      self.observable = "<Updated>" 
      println("Updated value to \(self.observable)"); 
     }) 
    } 
} 

class Observer: NSObject { 
    init(source: Source) { 
     super.init() 

     source.rac_valuesForKeyPath("observable", observer: self).subscribeNext { (value: AnyObject!) -> Void in 
      println(">>> Observable value changed: \(value)") 
     } 
    } 
} 

此例产生以下输出:

>>> Observable value changed: <Original> 
Updated value to <Updated> 

这意味着subcribeNext块不被调用。

预期的输入是:

>>> Observable value changed: <Original> 
Updated value to <Updated> 
>>> Observable value changed: <Updated> 

任何线索如何解决这个问题?

回答

9

可观察到的需求是动态的

我得到你的样品用下面的代码

class Source: NSObject { 
    dynamic var string:String = "Initial Value" 

    override init() { 
    super.init() 
    } 
} 

class Observer: NSObject { 

    init(source:Source) { 
    super.init() 
    source.rac_valuesForKeyPath("string", observer: self).subscribeNext { (newVal:AnyObject!) -> Void in 
     println(newVal) 
    } 
    } 
} 

class ViewController: UIViewController { 
    var source:Source! 
    var obs:Observer! 

    override func viewDidLoad() { 
    super.viewDidLoad() 
    source = Source() 
    obs = Observer(source: source) 
    source.string = "Another Value" 
    } 
} 
+0

这工作的人!非常感谢! – 2014-10-13 11:12:51

+1

在向第一个示例中添加“动态”修饰符时似乎工作 – 2015-03-09 17:25:40

+0

键值观察是一种机制,允许通知对象更改其他对象的指定属性。只要该类继承自NSObject类,就可以使用Swift类的键值观察。您可以使用这三个步骤在Swift中实现键值观察。 https://developer.apple.com/library/ios/documentation/Swift/Conceptual/BuildingCocoaApps/AdoptingCocoaDesignPatterns.html – 2015-03-09 17:28:57