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

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之网络请求封装和数据解析细节(仅自己当笔记使用))