我一直在做的是,我有一个从 API 请求数据的函数,当我将两个条件分开的响应是 .success 和 .failure 作为 Alamofire 的默认响应时。我一直在使用转义闭包来检查响应是否成功,我将显示一些内容,否则将向用户返回错误。它工作正常,直到我想将它放入 UIRefresh 需要使用的选择器中。
这是我的代码:
获取数据功能:
@objc func GetData(completion: @escaping (Bool)->Void){
Alamofire.request("\(ConstanClass.http)/api/order?token=\(ConstanClass.token)").responseJSON { response in
switch response.result {
case .success:
if let value = response.result.value{
let json = JSON(value)
//Geting Json
completion(true)
}
case .failure(let error):
self.setErrorForm(self)
self.hud.dismiss(animated: true)
print(error)
completion(false)
}
}
}
从选择器调用:
refresher.addTarget(self, action: #selector(MyOrderController.GetData(completion:)), for: UIControlEvents.valueChanged)
这是错误:
Thread 1: EXC_BAD_ACCESS (code=257, address=0x1a1b50997c9)
此错误指向 .success
中的 completion(true)
。
最佳答案
问题是你无法做你正在做的事情。您为 UIRefreshControl
设置的选择器并且“值更改”事件必须具有非常具体的签名。请查看 UIControl
的“目标行动机制”部分文档。
选择器必须采用零个、一个或两个参数,并且这些参数只能是非常具体的参数。第一个(如果提供)必须是对控件的引用( sender
)。第二个(如果提供)必须是 UIEvent
.
您无法创建接受完成 block 的发送者。这就是坠机的原因。第一个参数被视为刷新控件,但代码将其视为闭包,因此 EXC_BAD_ACCESS
错误。
鉴于您使用 GetData
,请考虑这一点,完成处理程序在哪里传入?什么正在处理完成处理程序的结果?
鉴于没有任何东西可以处理这个完成处理程序,只需更改 GetData
(应命名为 getData
)不带参数并删除 completion
的使用.
@objc func getData(){
Alamofire.request("\(ConstanClass.http)/api/order?token=\(ConstanClass.token)").responseJSON { response in
switch response.result {
case .success:
if let value = response.result.value{
let json = JSON(value)
//Geting Json
}
case .failure(let error):
self.setErrorForm(self)
self.hud.dismiss(animated: true)
print(error)
}
}
}
并更新您的使用情况:
refresher.addTarget(self, action: #selector(getData), for: UIControlEvents.valueChanged)
关于ios - Swift:带有 @escaping 闭包的选择器返回 EXC_BAD_ACCESS,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52142650/