Нужна помощь в заполнении табличного представления данными JSON после запроса POST - PullRequest
0 голосов
/ 06 июня 2019

По сути, мне нужно отображать данные JSON в виде таблицы после выполнения запроса POST, и API отвечает JSON.

Я не получаю ошибок, но также не получаю никакого ответа JSON, который отображается вотладчик.Я не уверен, что именно не так, но кажется, что ничего не загружается и не отображается в виде таблицы.

Ниже приведена структура, которую я использую для интерпретации JSON:

import UIKit

struct ScheduleStructure: Codable {
    let customer: String
    let PickedUpNUM: String
    let DeliveryNUM: String

}

Вот как должен выглядеть JSON:

[
    {
        "customer": “Example”,
        "PickedUpNUM": “2”,
        "DeliveryNUM": “4”
    }
]

В настоящее время этоконтроллер tableview:

import UIKit



class ScheduleCell: UITableViewCell {
    @IBOutlet weak var cellStructure: UIView!
    @IBOutlet weak var testingCell: UILabel!
    @IBOutlet weak var pickupLabel: UILabel!
    @IBOutlet weak var deliveryLabel: UILabel!
}

class ScheduleTableViewController: UITableViewController {

    var driverName = UserDefaults.standard.string(forKey: "name")!


    var structure = [ScheduleStructure]()

    override func viewDidLoad() {
        super.viewDidLoad()
    UINavigationBar.appearance().isTranslucent = false

        self.view.backgroundColor = UIColor.white


        //Adds Shadow below navigation bar
        self.navigationController?.navigationBar.layer.masksToBounds = false
        self.navigationController?.navigationBar.layer.shadowColor = UIColor.lightGray.cgColor
        self.navigationController?.navigationBar.layer.shadowOpacity = 0.8
        self.navigationController?.navigationBar.layer.shadowOffset = CGSize(width: 0, height: 2.0)
        self.navigationController?.navigationBar.layer.shadowRadius = 2


        self.extendedLayoutIncludesOpaqueBars = true
        fetchJSON()
        let refreshControl = UIRefreshControl()
        refreshControl.addTarget(self, action: #selector(doSomething), for: .valueChanged)
        tableView.refreshControl = refreshControl

    }



    private func fetchJSON() {
        guard
            let url = URL(string: "https://example.com/example/example.php"),
            let value = driverName.addingPercentEncoding(withAllowedCharacters: .urlQueryValueAllowed)
            else { return }

        var request = URLRequest(url: url)
        request.httpMethod = "POST"
        request.httpBody = "value=\(value)".data(using: .utf8)

        URLSession.shared.dataTask(with: request) { data, _, error in
            DispatchQueue.main.async {
                //
            }
            }.resume()

    }

    @objc func doSomething(refreshControl: UIRefreshControl) {
        print("reloaded")

        fetchJSON()

    }



    override func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
        return structure.count
    }

    override func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {


        let cell = tableView.dequeueReusableCell(withIdentifier: "customerID", for: indexPath) as! ScheduleCell



        cell.textLabel?.font = .boldSystemFont(ofSize: 18)
        cell.textLabel?.textColor = UIColor.red

        let portfolio = structure[indexPath.row]

        cell.textLabel?.text = portfolio.customer


        return cell

    }

    override func tableView(_ tableView: UITableView, didSelectRowAt indexPath: IndexPath) {


        let cell = tableView.dequeueReusableCell(withIdentifier: "customerID", for: indexPath) as! ScheduleCell
        //cell.cellStructure.layer.cornerRadius = 50
        let portfolio = structure[indexPath.row]


        let navigationController = UINavigationController(rootViewController: controller)

        self.present(navigationController, animated: true, completion: nil)

    }


    override func viewWillAppear(_ animated: Bool) {
        fetchJSON()

    }



}

Пожалуйста, дайте мне знать, если есть совершенно лучший способ сделать это

Мне просто нужно сделать JSON POST и отобразить результат в таблице.

Ответы [ 2 ]

0 голосов
/ 06 июня 2019

Я полагаю, вы знаете, что тело вашего dataTask на самом деле ничего не делает с данными, которые оно получает? Там просто пустой комментарий.

Я думаю, вы захотите сделать что-то вроде этого:

if let data = data {
    do {
        self.structure = try JSONDecoder().decode(Array<ScheduleStructure>.self, from: data)
        self.reloadData()
    } catch {
        print("TODO: handle parse error: \(error)")
    }
} else {
    print("TODO: handle network error: \(error)")
}
0 голосов
/ 06 июня 2019

Вам нужно декодировать ответ json как массив внутри обратного вызова к API

URLSession.shared.dataTask(with: request) { data, _, error in 
       guard let data = data else { return }
       do {
         self.structure = try JSONDecoder().decode([ScheduleStructure].self,from:data)
          DispatchQueue.main.async {
           self.tableView.reloadData()
          }
        }
        catch {
          print(error)
        } 

}.resume()

struct ScheduleStructure: Codable {
    let customer, pickedUpNUM, deliveryNUM: String

    enum CodingKeys: String, CodingKey {
        case customer
        case pickedUpNUM = "PickedUpNUM"
        case deliveryNUM = "DeliveryNUM"
    }
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...