美文网首页iOS收录
二十二、Swift3.0之网络请求封装和数据解析细节(仅自己当笔

二十二、Swift3.0之网络请求封装和数据解析细节(仅自己当笔

作者: ZhengYaWei | 来源:发表于2017-03-15 23:10 被阅读302次

    SWift3.0中网络请求一般是使用Alamofire框架。

    简单get和post网络请求封装。

    类名命名为ZWNetworkTools。注意使用cocoapod要导入头文件,这是因为命名空间的缘故。

    import UIKit
    import Alamofire
    enum MethodType {
        case get
        case post
    }
    class NetworkTools: NSObject {
        //参数别人可能传也可能不传,所以用可选?
        class func requestData(type: MethodType, URLString: String,parameters: [String : Any]? = nil, finishedCallback: @escaping (_ result: Any) -> ()){
            let method = type == .get ? HTTPMethod.get : HTTPMethod.post
             Alamofire.request(URLString, method: method, parameters: parameters).responseJSON { (response) in
                guard let result = response.result.value else{
                    //这里出现错误
                    print(response.result.error ?? "")
                    return
                }
                finishedCallback(result)
            }
        }
    }
    

    网络请求数据解析细节

     NetworkTools.requestData(type: .get, URLString: "http://capi.douyucdn.cn/api/v1/getHotCate", parameters: parameters) { (result) in
                //print(result)
                
                //因为可选项不能参与计算,所以要guard let
                //其实只要理解?是定义时使用,!是在计算之前的准备就可以。
                //1、result原本是Any类型,一般直接转为字典,并且还要守护,因为可能转化字典无法成功。
                guard let resultDict = result as? [String: NSObject] else{return}
                //2、根据data的key,获取字典数组
                guard let dataArray = resultDict["data"] as? [[String: NSObject]] else {return}
                //3、遍历数组,获取字典,并且将字典转为模型对象
                //目前swift中还没有比较好的第三方字典转模型框架
                for dict in dataArray{
                    //这里涉及计算,所以上面直接守护了dataArray
                    let group = AmchorGroup(dict: dict)
                    self.anchorGroup.append(group)
                }
                for group in self.anchorGroup{
                    print(group.tag_name)
                }
                dGroup.leave()
            }
    
    

    模型的实现。可以参考第16节。

    class AmchorGroup: NSObject {
        //给基本数据类型初始化
        //使用KVC会提示无法找到age的KEY,因为Int是一个基本数据类型的结构体,OC中只有基本数据类型。因此对于基本数据类型要设置初始值。
        //var age: Int = 0
        
        //该组中对应的房间信息
        var room_list : [[String : NSObject]]?
        var tag_name: String = ""
        var icon_name: String = ""
        
        //这里涉及计算,所以就不要设置为可选了  对外提供的参数之间为不可选的
        init(dict: [String: NSObject]) {
            super.init()
            setValuesForKeys(dict)
        }
        
        override func setValue(_ value: Any?, forUndefinedKey key: String) {
            
        }
    }
    

    同一页面多个网络请求的处理

    func requestData(finishedCallBack: @escaping () -> ()){
            let parameters = ["limit" : "4", "offset" : "0", "time" : NSDate.getCurrentTime()]
            
            let dGroup = DispatchGroup()
            //1、请求推荐数据
            dGroup.enter()
            NetworkTools.requestData(type: .get, URLString: "http://capi.douyucdn.cn/api/v1/getbigDataRoom", parameters: ["time" : NSDate.getCurrentTime()]) { (result) in
                //print(result)
                dGroup.leave()
            }
            //2、请求颜值数据
            dGroup.enter()
            NetworkTools.requestData(type: .get, URLString: "http://capi.douyucdn.cn/api/v1/getVerticalRoom", parameters: parameters) { (result) in
                dGroup.leave()
            }
            //3、请求后面部分的游戏数据
            dGroup.enter()
            NetworkTools.requestData(type: .get, URLString: "http://capi.douyucdn.cn/api/v1/getHotCate", parameters: parameters) { (result) in
              
                dGroup.leave()
            }
            dGroup.notify(queue: DispatchQueue.main) {
                //上面三分每次请求的网络数据可以分别用一个数组去记录。三个网络数据都请求成功后,可以将网络数据在这里面拼接
                finishedCallBack()
            }
        }
    

    相关文章

      网友评论

        本文标题:二十二、Swift3.0之网络请求封装和数据解析细节(仅自己当笔

        本文链接:https://www.haomeiwen.com/subject/rhnrnttx.html