在 swift 中允许在 @escaping 中使用多个可选参数
Allow Multiple optional parameter in @escaping in swift
我有这个方法:
func getdata(someString: String, onComplete: @escaping ((_ someArrayData: [String], _ error: Error?) -> Void)) {
var result: [BanPhone] = []
// Some Actions
if(someaction is successful)
{
onComplete(result)
}
else {
onComplete(result, Error)
}
}
错误是可选的我只想在出现错误时传递此参数。否则我想发回结果。
我怎么能在这里做到这一点
在回答你的问题时,你在成功时用结果调用它,为错误参数传递 nil
,例如成功场景:
onComplete(result, nil)
如果有错误,你会调用它提供错误代码,但没有值:
onComplete(nil, error)
现在我们一般会用Result
type. See https://www.swiftbysundell.com/basics/result/进行实际讨论。
我们赞成 Result
而不是“两个可选参数”模式,因为它向调用者明确表示要么成功并返回一个值,要么失败并返回一个错误,两者兼而有之,但是两者都不是。
func fetchData(with someString: String, completion: @escaping (Result<[String], Error>) -> Void)) {
...
doingSomethingAsynchronous {
...
// if failed
if let error = error {
completion(.failure(error))
return
}
// if successful
completion(.success(value))
}
}
并像这样使用它:
fetchData(with: string) { result in
switch result {
case .failure(let error):
print(error)
case .success(let value):
// do something with `value`
}
}
现在,这就是两个可选参数模式在实践中的工作方式(它是一个或另一个),但是 Result
使合同形式化,使您免于展开可选参数等
我有这个方法:
func getdata(someString: String, onComplete: @escaping ((_ someArrayData: [String], _ error: Error?) -> Void)) {
var result: [BanPhone] = []
// Some Actions
if(someaction is successful)
{
onComplete(result)
}
else {
onComplete(result, Error)
}
}
错误是可选的我只想在出现错误时传递此参数。否则我想发回结果。 我怎么能在这里做到这一点
在回答你的问题时,你在成功时用结果调用它,为错误参数传递 nil
,例如成功场景:
onComplete(result, nil)
如果有错误,你会调用它提供错误代码,但没有值:
onComplete(nil, error)
现在我们一般会用Result
type. See https://www.swiftbysundell.com/basics/result/进行实际讨论。
我们赞成 Result
而不是“两个可选参数”模式,因为它向调用者明确表示要么成功并返回一个值,要么失败并返回一个错误,两者兼而有之,但是两者都不是。
func fetchData(with someString: String, completion: @escaping (Result<[String], Error>) -> Void)) {
...
doingSomethingAsynchronous {
...
// if failed
if let error = error {
completion(.failure(error))
return
}
// if successful
completion(.success(value))
}
}
并像这样使用它:
fetchData(with: string) { result in
switch result {
case .failure(let error):
print(error)
case .success(let value):
// do something with `value`
}
}
现在,这就是两个可选参数模式在实践中的工作方式(它是一个或另一个),但是 Result
使合同形式化,使您免于展开可选参数等