目錄:[Swift]Xcode實際操做html
本文將演示如何經過Get請求方式,異步獲取GitHub資源的詳細信息。ios
異步請求與同步請求相比,不會阻塞程序的主線程,而會創建一個新的線程。git
在項目導航區,打開視圖控制器的代碼文件【ViewController.swift】github
1 import UIKit 2 3 class ViewController: UIViewController { 4 5 //給當前視圖控制器類,添加一個標籤屬性。 6 //該標籤對象,將用來顯示遠程服務器返回的信息 7 var label = UILabel() 8 9 override func viewDidLoad() { 10 super.viewDidLoad() 11 // Do any additional setup after loading the view, typically from a nib. 12 13 //設置標籤對象的位置在(20,40),尺寸爲(280,500) 14 label.frame = CGRect(x: 20, y: 40, width: 280, height: 500) 15 //設置標籤對象的文字內容 16 label.text = "Loading..." 17 //設置標籤對象的字體和大小 18 label.font = UIFont(name: "Arial", size: 12) 19 //設置標籤對象的背景顏色爲淺灰色 20 label.backgroundColor = UIColor.lightGray 21 //設置標籤對象的行數屬性值爲0,表示不限制標籤對象的行數 22 label.numberOfLines = 0 23 //遠程服務器有可能返回較多的文字內容, 24 //在此設置標籤對象在進行換行時,保留全部的字符 25 label.lineBreakMode = NSLineBreakMode.byWordWrapping 26 //將設置好的標籤對象,添加到當前視圖控制器的根視圖 27 self.view.addSubview(label) 28 29 //建立一個網址對象,指定請求網絡數據的網址。 30 let url = URL(string: "https://api.github.com/repos/tulios/json-viewer") 31 32 //建立一個網絡請求對象,參數說明: 33 //1.表明請求訪問的路徑 34 //2.表明網絡請求的緩存協議 35 //3.表明網絡請求的超時時間 36 let request = URLRequest.init(url: url!, 37 cachePolicy: .useProtocolCachePolicy, 38 timeoutInterval: 30) 39 40 //網址會話URLSession在2013年發佈,蘋果對它的定位是做爲舊的網絡請求接口的替代者。 41 //這裏得到網址會話的單例對象 42 let session = URLSession.shared 43 //全部網絡請求工做,都是經過網址會話任務對象來完成的。 44 //能夠使用閉包、代理或者二者混合的方式,來建立網絡請求任務。 45 //建立一個網絡請求任務,根據指定的網址請求對象,獲取接口的內容, 46 //並在完成時經過閉包語句,處理服務器返回的數據 47 let task = session.dataTask(with: request, completionHandler: {(data, response, error) -> Void in 48 //若是出現網絡請求錯誤, 49 if error != nil{ 50 //則在控制檯打印輸出錯誤代碼和錯誤信息 51 print(error.debugDescription) 52 }else{ 53 //將網絡返回的數據對象,根據指定的編碼方式,轉換爲字符串 54 let result = String(data: data!, encoding: String.Encoding.utf8) 55 //當在一個線程中,須要更改界面元素時,須要返回程序的主線程 56 DispatchQueue.main.async(execute: { () -> Void in 57 //更新標籤對象的文字內容 58 self.label.text = result! as String 59 }) 60 } 61 }) 62 63 //任務建立後,調用resume方法開始工做。 64 task.resume() 65 } 66 67 override func didReceiveMemoryWarning() { 68 super.didReceiveMemoryWarning() 69 // Dispose of any resources that can be recreated. 70 } 71 }