I connected to API using Alamofire and SwiftyJson.
I got this JSON return:
{
"contacts": [
{
"id": "c200",
"name": "Ravi Tamada",
"email": "",
"address": "xx-xx-xxxx,x - street, x - country",
"gender" : "male",
"phone": {
"mobile": "+91 0000000000",
"home": "00 000000",
"office": "00 000000"
}
},
{
"id": "c201",
"name": "Johnny Depp",
"email": "",
"address": "xx-xx-xxxx,x - street, x - country",
"gender" : "male",
"phone": {
"mobile": "+91 0000000000",
"home": "00 000000",
"office": "00 000000"
}
},
{
"id": "c202",
"name": "Leonardo Dicaprio",
"email": "",
"address": "xx-xx-xxxx,x - street, x - country",
"gender" : "male",
"phone": {
"mobile": "+91 0000000000",
"home": "00 000000",
"office": "00 000000"
}
}
]
}
This is my ViewController code:
import UIKit
import Alamofire
import SwiftyJSON
class ViewController:UIViewController {
@IBOutlet weak var tblJSON: UITableView!
var arrRes = [[String : AnyObject]]()
override func viewDidLoad() {
super.viewDidLoad()
getRequest()
}
override func didReceiveMemoryWarning() {
super.didReceiveMemoryWarning()
// Dispose of any resources that can be recreated.
}
func getRequest() {
Alamofire.request("http://api.androidhive.info/contacts").responseJSON { (responseData) -> Void in
if ((responseData.result.value) != nil) {
let swiftyJsonVar = JSON(responseData.result.value!)
if let resData = swiftyJsonVar["contacts"].arrayObject {
self.arrRes = resData as! [[String : AnyObject]]
}
if self.arrRes.count > 0 {
self.tblJSON.reloadData()
}
}
}
}
//MARK: tableView
func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
return arrRes.count
}
func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
let cell : UITableViewCell = tableView.dequeueReusableCell(withIdentifier: "Cell")!
var dict = arrRes[indexPath.row]
cell.textLabel?.text = dict["name"] as? String
cell.detailTextLabel?.text = dict["email"] as? String
return cell
}
}
I have trouble displaying result on the UITableView. Can anyone help me? Thanks!
You need to implement UITableViewDataSource and UITableViewDelegate like this
class ViewController:UIViewController, UITableViewDataSource, UITableViewDelegate
and in viewDidLoad you need to assign DataSource and Delegate to your tableView like this
override func viewDidLoad() {
super.viewDidLoad()
tblJSON.dataSource = self
tblJSON.delegate = self
getRequest()
}