Свифт парсинг JSON и передача данных - PullRequest
0 голосов
/ 28 июня 2018

Я новичок в разработке для iOS. Передо мной стоит задача использовать api GitHub для получения данных об описании пользовательских списков.

Идея такова: Я ввожу имя пользователя в usernameTextField на первом viewcontroller (LoginViewController) И вы нажимаете searchTapped , переход запускается и выдает вас во второй контроллер вида (GistsViewController), где в tableview отображается описание, полученное от json Данные из json декодируются и добавляются в массив gists , а затем передаются через последовательность в GistsViewController. Но проект идет без ошибок, пока он не работает должным образом. Может кто-нибудь помочь мне отредактировать мой код?

Это моя модель:

struct Gists: Codable {
    let description: String?

    private enum CodingKeys: String, CodingKey {
        case description

    }
}

это первый viewController:

class LoginViewController: UIViewController {

    @IBOutlet weak var warningLabel: UILabel!
    @IBOutlet weak var usernameTextField: UITextField!

    var gists = [String]()
    var username: String?

    func displayWarningLabel(withText text: String) {
        warningLabel.text = text
        UIView.animate(withDuration: 3, delay: 0, usingSpringWithDamping: 1, initialSpringVelocity: 1, options: .curveEaseInOut, animations: { [weak self] in
            self?.warningLabel.alpha = 1
        }) { [weak self] complete in
            self?.warningLabel.alpha = 0
        }
    }

    override func viewDidLoad() {
        super.viewDidLoad()
        warningLabel.alpha = 0
    }

    @IBAction func unwindToMainScreen(segue: UIStoryboardSegue) {
        usernameTextField.text = ""
    }

    @IBAction func searchTapped(_ sender: UIButton) {
        guard let username = usernameTextField.text, username != "" else {
            displayWarningLabel(withText: "Information is incorrect")
            return
        }

        guard let gitUrl = URL(string: "https://api.github.com/users/\(username)/gists") else { return }
        URLSession.shared.dataTask(with: gitUrl) { (data, response, error) in 
            guard let data = data else { return }
            do {
                let decoder = JSONDecoder()
                let gitData = try decoder.decode([Gists].self, from: data)

                DispatchQueue.main.sync {
                    self.gists.append(gitData.description)
                }
            } catch let err {
                print("Err", err)
            }
            }.resume()

        performSegue(withIdentifier: "GistsSegue", sender: nil)
    }

    override func prepare(for segue: UIStoryboardSegue, sender: Any?) {
        guard let dvc = segue.destination as? GistsViewController else { return }
        dvc.username = usernameTextField.text
        dvc.gists1 = gists
        }
}

и это второй viewController:

class GistsViewController: UIViewController, UITableViewDelegate, UITableViewDataSource {

    var username: String!
    var gists1 = [String]()

    @IBOutlet weak var tableView: UITableView!

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

    func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
        let cell = tableView.dequeueReusableCell(withIdentifier: "Cell", for: indexPath)
        cell.backgroundColor = .clear
        cell.textLabel?.text = gists1[indexPath.row]
        self.tableView.reloadData()
        return cell
    }

    func tableView(_ tableView: UITableView, didSelectRowAt indexPath: IndexPath) {
        tableView.deselectRow(at: indexPath, animated: true)
    }

    override func viewDidLoad() {
        super.viewDidLoad()
        title = username
        tableView.tableFooterView = UIView(frame: .zero)
        tableView.dataSource = self
        tableView.delegate = self
        print(gists1)
    }

    @IBAction func addTapped(_ sender: UIBarButtonItem) {
    }     
}

Буду очень признателен за любую помощь!

1 Ответ

0 голосов
/ 28 июня 2018

Вызов api является асинхронным, поэтому вставьте performSegue в блок завершения

guard let gitUrl = URL(string: "https://api.github.com/users/\(username)/gists") else { return }
URLSession.shared.dataTask(with: gitUrl) { (data, response, error) in
    guard let data = data else { return }
    do {
        let decoder = JSONDecoder()
        let gitData = try decoder.decode([Gists].self, from: data)

        DispatchQueue.main.sync {
            self.gists.append(contentsOf:gitData)
            performSegue(withIdentifier: "GistsSegue", sender: nil)
        }
    } catch let err {
        print("Err", err)
    }
    }.resume()
...