- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
大家早上好!
我正在使用带有 Xcode10 的 Swift 4.2 开发一个应用程序,并使用 Alomofire 和 PromiseKit 管理调用。
有一次我需要在应用程序的开头加载一个屏幕,其中包含使用条款,但前提是他们已经更新了它。如果版本已更改,则同一调用将具有包含新端点的 URL。该端点包含要显示的文本。因此,在最后一种情况下。我们必须打两个电话。
然后我解释我想做什么:
要知道他们是否更新了版本号,我进行了第一次调用并检查了我保存在设备中的最后一个版本 (NSUsserDefaults)。第一次调用返回以下内容:
{ “合法版本”:“1”, “合法网址”:“http://statics.....html”
如果是同一个版本,我就不显示了。
如果版本发生变化,我想进行第二次调用(使用包含第一次调用“legal_URL”的答案的 URL)
他的问题是我不知道如何进行双重调用阻塞。所以不要在没有检查版本号的情况下加载主屏幕。而且不知道我是否必须再次显示法律条款屏幕。所有这些都是 PromiseKit 和嵌套调用。
非常感谢您的帮助。
[代码更新]
let legalWarningRepository = LegalWarningRepository()
firstly {
legalWarningRepository.get(endpoint: "http://myserver.com/version")
}.then { json in
if let remoteVersion = json["version"] as? String, let
legalUrl = json["legal_URL"] as? String,
remoteVersion != localVersion {
return legalWarningRepository.get(endpoint: legalUrl)
}
}.done { json in
if json == nil {
// display main screen
}
else {
// display legal terms
}
}.catch { err in
print(err)
}
在“legalWarningViewController”中,我有你传给我的 get 方法:
func get(endpoint: String) -> Promise<[String: Any]> {
return Promise { seal in
Alamofire.request(endpoint)
.validate()
.responseJSON { response in
switch response.result {
case .success(let json):
guard let json = json as? [String: Any] else {
return seal.reject(AFError.responseValidationFailed(reason:
.dataFileNil))
}
seal.fulfill(json)
case .failure(let error):
seal.reject(error)
}
}
}
}
最佳答案
在您的第一个屏幕上,您可以在等待响应时显示一个事件指示器。收到回复后,您就可以显示相应的 View 。
为了简单起见,您可以创建一个通用方法来“promisify”Alamofire 调用:
func get(endpoint: String) -> Promise<[String: Any]> {
return Promise { seal in
Alamofire.request(endpoint)
.validate()
.responseJSON { response in
switch response.result {
case .success(let json):
guard let json = json as? [String: Any] else {
return seal.reject(AFError.responseValidationFailed(reason: .dataFileNil))
}
seal.fulfill(json)
case .failure(let error):
seal.reject(error)
}
}
}
}
然后在主屏幕的 viewDidLoad
或 viewWillAppear
中,您可以执行以下逻辑:
firstly {
get(endpoint: "http://myserver.com/version")
}.then { json in
if let remoteVersion = json["version"] as? String, let legalUrl = json["legal_URL"] as? String, remoteVersion != localVersion {
return get(endpoint: legalUrl)
}
}.done { json in
if json == nil {
// display main screen
}
else {
// display legal terms
}
}.catch { err in
print(error.localizedDescription)
}
在您的情况下,如果您在 WKWebView
中显示法律术语,则可能会进行一次调用。
firstly {
get(endpoint: "http://myserver.com/version")
}.done { json in
if let remoteVersion = json["version"] as? String, let legalUrl = json["legal_URL"] as? String, remoteVersion != localVersion {
// display legal terms in a web view
}
// display main screen
}.catch { err in
print(error.localizedDescription)
}
关于ios - Swift 4 - 使用 PromiseKit 调用嵌套,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53172638/
我正在使用 swift 3 在 Xcode 8.2.1 上开发一个应用程序。我有一些异步任务需要按适当的顺序排列,因此我决定为此目的使用 PromiseKit。我在我的项目目录中添加了一个 podfi
我有一些昂贵的 promise ,在不同的地方被调用。理想情况下,我只想链接现有的飞行 promise (使用可选的强制),所以我发现自己在做这样的事情: class Expensive { va
ReactiveSwift具有称为flatMapError的强大功能,允许您在发生错误时以事件流进行响应。一个简单的示例可能如下所示: authenticationProducer.flatMapEr
我正在将 PromiseKit 集成到我们当前的系统中,我需要链的 catch 部分使用 2 个参数。我希望我的 catch 使用 error, fetcher 而不仅仅是错误。执行此操作的最佳方法是
刚开始在 Swift 中使用 PromiseKit 6。我检查了一些示例并阅读了文档。我有一个看似微不足道的场景,但我无法绕过它。我有以下场景: func addModel(_ model: Mode
刚开始使用 PromiseKit 遇到了一个奇怪的问题编译问题: with firSTLy:对成员“firSTLy(execute:)”的引用不明确 () without firSTLy:无法推断复杂
我是编程新手。因此,安装 PromiseKit 对我来说一直很困难。在研究了各种安装方法后,我尝试通过 Carthage 安装(结果没有成功,因为我不得不弄清楚如何安装 Carthage,但我从来没能
我的应用程序中有一系列 UIViewController(弹出窗口),用于从最终用户那里收集信息。我设法用这样的 promise 将它们链接起来: firstly { return s
我目前正在混合使用 SwiftyStoreKit 和 PromiseKit 以处理应用内购买,我遇到的问题/问题是在 promise 链中,如果我在其中一个中抛出错误,则 catch block 不是
我正在使用 PromiseKit 来处理我的网络调用。我正在尝试查看是否有约定或更简洁的方法来尽早履行或拒绝 promise 。如下图所示,有一些条件需要我提前满足或拒绝。我目前通过在之后放置一个 r
我如何进行可选 promise 链接?例如,我有两个 promise ,我必须仅根据第一个 promise 结果的某些条件来检查第二个 promise 。 promise1(). then { res
假设您的 Promise 链中有一个分支,它可以不返回任何内容,也可以返回 AnyObject Promise。您将指定什么作为“then”闭包的返回类型?例如: func sample() -> P
我已经开始在异步请求中使用 PromiseKit,但现在遇到一个问题,我无法解析链中的错误。我有一个请求管理器,其方法如下: func request( url: String,
我正在使用 PromiseKit(很棒的框架,顺便说一句!)来处理我的应用程序和服务器 API 之间的通信。我想创建某种全局处理程序来响应诸如通知用户我的许多 promise 中的任何一个缺乏网络连接
我可以在 AppDelegate - application:didReceiveRemoteNotification 方法中使用 PromiseKit 吗? 我正在使用 GCM 从服务器推送通知。一
使用 Swift,我第一次尝试使用 PromiseKit 将 promises 合并到我的代码中,但我很难从语法上理解如何实现它。 我的目标是通过管道将请求传递给 Firebase 以获取数据,并在附
我试图在 promise 工具包上链接一些 promise,当 promise 类型像这样时我遇到语法问题 Promise ,只有当 promise 有类型时,我才会收到编译器错误。我刚开始使用 pr
我正在尝试使用 PromiseKit,但在解决这个问题时遇到了一些麻烦。我有一个函数可以做类似的事情 func lengthyOperation() -> Promise { return Pr
PromiseKit 提供了一个方便的方法 thenOn 用于在非主线程上运行你的部分链。然而,似乎没有任何方便的方法来设置第一个 promise 执行线程。 这意味着我最终要么在我的第一个 prom
我有下一个递归 Promise 函数调用: func getPlaces(location: Location) -> Promise { return Promise().then {
我是一名优秀的程序员,十分优秀!