Man*_*nny 10 architecture mvvm swift rx-swift
我正在尝试将项目转换为使用RxSwift和MVVM.我有一个服务,在每个应用程序启动时同步来自Parse的数据列表,我基本上想确保我采取正确的方法.
我所做的是成为一个可变主题,然后允许我的模型听这个.ParseService:
let rx_parseMushrooms = Variable<[ParseMushroom]>([])
Run Code Online (Sandbox Code Playgroud)
MushroomLibraryModel:
_ = parseService.rx_parseMushrooms
.asObservable()
.map { (parseMushrooms:[ParseMushroom]) -> [Mushroom] in
let mushrooms = parseMushrooms.map { (parseMushroom:ParseMushroom) -> Mushroom in
let mushroom = Mapper<Mushroom>().map(parseMushroom.dictionaryWithValuesForKeys(parseMushroom.allKeys()))
return mushroom!
}
return mushrooms
}
.subscribeNext({ (mushrooms:[Mushroom]) -> Void in
self.mushrooms = mushrooms
print(mushrooms)
})
Run Code Online (Sandbox Code Playgroud)
我也是这样表达同步状态的.
ParseService:
struct SyncState {
enum State {
case Unsynced, ConnectingToServer, SyncingInfo, FetchingImageList, SyncingImages, SyncComplete, SyncCompleteWithError
}
var infoToSync = 0
var imagesToSync = 0
var imagesSynced = 0
var state = State.Unsynced
}
let rx_syncState = Variable(SyncState())
Run Code Online (Sandbox Code Playgroud)
然后我更新变量a la
self.rx_syncState.value = self.syncState
Run Code Online (Sandbox Code Playgroud)
SyncViewModel:
_ = parseService.rx_syncState
.asObservable()
.subscribeNext { [weak self] (syncState:ParseService.SyncState) -> Void in
switch syncState.state {
//show stuff based on state struct
}
}
Run Code Online (Sandbox Code Playgroud)
无论如何,如果有人能告诉我这是否是一个很好的解决方法,或者我是否在滥用RxSwift(并指导我如何做到这一点......),我将不胜感激.
干杯!
嗯......这是一篇关于使用Variable的文章(请注意,Variable是BehaviorSubject的包装器.)
http://davesexton.com/blog/post/To-Use-Subject-Or-Not-To-Use-Subject.aspx
在您的情况下,您已经有一个冷可观察(网络呼叫),因此您不需要主题/变量.您需要做的就是发布已有的observable并使用replay(1)来缓存该值.我希望一个名为like的类ParseServer包含一个名为like的计算属性mushrooms.
为了帮助解析蘑菇,你可以使用它(这将创建你需要的冷观察):
extension PFQuery {
var rx_findObjects: Observable<[PFObject]> {
return Observable.create { observer in
self.findObjectsInBackgroundWithBlock({ results, error in
if let results = results {
observer.on(.Next(results))
observer.on(.Completed)
}
else {
observer.on(.Error(error ?? RxError.Unknown))
}
})
return AnonymousDisposable({ self.cancel() })
}
}
}
Run Code Online (Sandbox Code Playgroud)
然后你会有类似的东西:
class ParseServer {
var mushrooms: Observable<[Mushroom]> {
return PFQuery(className: "Mushroom").rx_findObjects
.map { $0.map { Mushroom(pfObject: $0) } }
.publish()
.replay(1)
}
}
Run Code Online (Sandbox Code Playgroud)
我认为以上是正确的.我没有通过编译器运行它,更不用说测试了它.它可能需要编辑.
但这个想法是,第一次调用myParseServer.mushrooms系统时会调用Parse来获取蘑菇并缓存它们.从那时起,它将只返回以前的兑现蘑菇.
| 归档时间: |
|
| 查看次数: |
10605 次 |
| 最近记录: |