最近在学习ios开发,刚刚学习了一下swift
我们都知道访问网络一般都是通过回调的形式来实现的,这里我搜索了下,学习到了3种方法,当然肯定有其他的方式,不过常用或者说比较容易理解的就是这三种
一、使用protocol的方式
首先声明一个protocol NetCallback,类似于java中的接口/抽象类,里面一个方法
然后在类中输入声明一个方法,参数类型是NetCallback
import UIKit
protocol NetCallBack {
func success(result:String)
}
import UIKit
class NetHelper: NSObject {
static func get(url:String ,callback:NetCallBack){
NSLog("url=%@", url)
callback.success(result: "访问\(url)成功");
}
}
调用
struct cb:NetCallBack{
func success(result:String){
NSLog("结果是:%@", result)
}
}
NetHelper.get(url: "www.baidu.com", callback: cb() as NetCallBack)
这样就可以实现调用,也很好理解,声明一个构造体实现了NetCallBack协议,然后将构造体cb作为一个参数传入,方法体内就会掉到success
二、使用闭包作为目标字段的方式
闭包的话,可以参考下网上的blog帖子啥的
class NetHelper: NSObject {
var url:String
static func get(url:String ,callback:NetCallBack){
NSLog("url=%@", url)
callback.success(result: "访问\(url)成功");
}
func exec(){
getCallBack!("result")
}
var getCallBack:((String)->(Void))?
init(url:String){
self.url = url
}
}
这里的getCallBack声明了一个变量类型是需要传String参数,没有返回值
调用
let helper:NetHelper = NetHelper(url: "www.sina.com")
helper.getCallBack = {(result)->Void in
NSLog("结果为:\(result)")
}
helper.exec()
这里大概就是声明了一个对象,设置对象的callBack为自己定义的闭包,最后log输出 结果为:result
三、直接在方法中声明闭包作为参数
这也是比较被推荐的一个,因为使用时结构清晰,也容易理解
class NetHelper: NSObject {
var url:String
init(url:String){
self.url = url
}
func exec(cb: (_ result:String)->()){
NSLog("访问%@", url)
cb("json");
}
}
使用时
let helper:NetHelper = NetHelper(url: "www.sina.com")
helper.exec { (result) in
NSLog("闭包回调结果是:\(result)")
}
这里输出结果为: 闭包回调结果是:json
结语
这三种方式,根据自己的实际需要来用,其实我个人觉得第三种比较合适,将请求封装,回调也比较清楚,失败的回调下次再研究
本文介绍了在iOS开发中使用Swift进行网络回调的三种常见方法:1) 使用protocol,通过实现协议回调;2) 将闭包作为目标字段;3) 直接在方法中声明闭包作为参数。每种方法都有其适用场景,作者个人倾向于第三种,因为它使请求封装更清晰,回调逻辑更直观。
2113

被折叠的 条评论
为什么被折叠?



