第一次使用螺栓,我几乎可以理解它们是如何工作的,但是我确信必须有一种更清洁的方式来做我正在做的事情。
在我的示例中,我想下载一个带有类别的 JSON,将它们导入 Core Data,然后下载一个带有成分的 JSON,并将它们也导入。事情需要按此顺序发生,因为我的解析器要求Category
对象在解析对象之前已经存在Ingredient
。
我正在使用BoltsSwift以避免嵌套块,所以我让我的“下载器”和“导入器”返回一个Task
.
网络调用(使用 Moya):
static func downloadJSON(target: MoyaAPI) -> BoltsSwift.Task<JSONArray> {
let taskCompletionSource = TaskCompletionSource<JSONArray>()
requestJSONArray(target, success: { (jsonArray) in
taskCompletionSource.set(result: jsonArray)
}, error: { (error) in
taskCompletionSource.set(error: error)
}, failure: { (moyaError) in
taskCompletionSource.set(error: moyaError)
})
return taskCompletionSource.task
}
解析部分(使用 Groot):
func importCategories(from json: JSONArray) -> BoltsSwift.Task<[Category]> {
let taskCompletionSource = TaskCompletionSource<[Category]>()
do {
let categories: [Category] = try objects(fromJSONArray: json, inContext: managedObjectContext)
taskCompletionSource.set(result: categories)
} catch {
taskCompletionSource.set(error: error)
}
return taskCompletionSource.task
}
所以后来当我尝试将这 4 个任务实际链接在一起时,我想出了这个:
NetworkAdapter.downloadJSON(target: .categories).continueOnSuccessWithTask { (json) -> Task<[Category]> in
return importer.importCategories(from: json)
}.continueOnSuccessWith { (categories) in
return NetworkAdapter.downloadJSON(target: .ingredients).continueOnSuccessWithTask(continuation: { (json) -> Task<[Ingredient]> in
return importer.importIngredients(from: json)
})
}
这行得通,但我觉得语法可以更具可读性。有人能解释一下很好地链接这 4 个任务的正确方法是什么吗?