1.获取网络数据
第一步:创建网络对象
let url = NSURL(string: "http://apis.baidu.com/txapi/huabian/newtop?num=20&page=1")
第二步:创建请求
let request = NSMutableURLRequest(URL: url!)
需要注意的是在请求头中必须添加apikey(没有apikey无法获取数据)
request.addValue("4ab786262728e6475f7dfebf07e1a86a", forHTTPHeaderField: "apices")
第三步:创建会话
let session = NSURLSession.sharedSession()
有了会话就可以创建3种不同类型的任务
- NSURLSessionDataTask-从服务器获取数据任务
- NSURLSessionUploadTask-上传
3.NSURLSessionDownloadTask-下
载
第四步:创建获取数据任务
let dataTask = session.dataTaskWithRequest(request) { (data, response, error) in
//表示拿到数据
if error == nil{
//把jason格式数据转成一个数组或字典,也可以反过来
//通过NSJSONSerialization类将NSData解成字典
let dict = try! NSJSONSerialization.JSONObjectWithData(data!, options: .MutableContainers) as! [String:AnyObject]
//从字典中取出明为newslist键对应的数组
if let array = dict["newslist"] as? [[String:String]]{
//数组中的元素又是一个字典正好对应一个模型对象
for objDict in array{
//没次循环创建一个模型对象
let model = NewsModel()
//一句话直接用字典对象给模型的所有属性赋上对应的值
//KVC-Key Value Coding(键值对编码)
//字典中的键对应对象的某个属性。字典中键对应的值就是属性值
//kvc不是swift中的内容,如果要使用kvc类需要继承NSObjiect
model.setValuesForKeysWithDictionary(objDict)
//给模型对象赋值
/*
model.title = obj["title"]!
model.ctime = obj["ctime"]!
model.picUrl = obj["picUrl"]!
model.url = obj["url"]!
*/
self.dataArray.append(model)
}
//由于解析数据的代码并没有在主线程中执行,因此在刷新表格视图前,应该让刷新表格视图的代码重新回到主线程中执行,苹果要求刷新UI的代码必须会回道主线程
//刷新表格视图
dispatch_async(dispatch_get_main_queue(), {
//通过gcd的异步派发操作回到主线程刷新表格视图
self.tableView.reloadData()
})
}
}else{
print("从服务器获取数据失败!!!!")
}
}
//恢复执行任务
//resume()方法是一个异步执行的方法,所谓异步就是没有阻碍当前主线程而是在一个新的线程(并发线程)中去执行
dataTask.resume()
}
网友评论