我试图在Swift中提出一个简单的可观察对象,并考虑使用RxSwift。我找不到一个简单的例子来做这样的事情:
protocol PropertyObservable {
typealias PropertyType
var propertyChanged: Event<(PropertyType, Any)> { get }
}
class Car: PropertyObservable {
typealias PropertyType = CarProperty
let propertyChanged = Event<(CarProperty, Any)>()
dynamic var miles: Int = 0 {
didSet {
propertyChanged.raise(.Miles, oldValue as Any)
}
}
dynamic var name: String = "Turbo" {
didSet {
propertyChanged.raise(.Name, oldValue as Any)
}
}
}
上面是来自this blog post的可观测量的纯Swift解决方案;我真的很喜欢它是一种基于协议的解决方案,而不是侵入性的。在我的例子中,我的项目中有一个对象,其中每个属性都在引擎盖下异步设置(蓝牙设备)。因此,我需要观察/订阅更改,而不是实时获取/设置属性。
我一直听到RxSwift会做到这一点以及更多。但是,我找不到一个简单的例子来匹配上面并开始认为RxSwift对我的需要是否过度?谢谢你的帮助。
答案 0 :(得分:3)
使用RxSwift快速制作此可观察对象的最简单方法可能是使用RxSwift类变量(这里的所有代码都是未经测试的):
import RxSwift
class Car {
var miles = Variable<Int>(0)
var name = Variable<String>("Turbo")
}
这使您可以通过订阅来观察值:
let disposeBag = DisposeBag()
let car = Car
car.name.asObservable()
.subscribeNext { name in print("Car name changed to \(name)") }
.addToDisposeBag(disposeBag) // Make sure the subscription disappears at some point.
现在你在每个事件中都丢失了旧值。当然有很多方法可以解决这个问题,RxSwifty方法可能是添加一个scan operation to your element sequence,它的工作原理与普通数组上的reduce相似:
car.name.asObservable()
.scan(seed: ("", car.name.value)) { (lastEvent, newElement) in
let (_, oldElement) = lastEvent
return (oldElement, newElement)
}
.subscribeNext { (old, new) in print("Car name changed from \(old) to \(new)") }
.addToDisposeBag(disposeBag)