Swift 5:从tableView numberOfRowsInSection返回数组计数时索引超出范围

时间:2019-06-09 15:17:30

标签: ios swift uitableview uikit

我几乎已经解决了这个问题。这是唯一剩下要解决的事情。

这是我要解析的内容: https://newsapi.org/v2/top-headlines?country=us&category=business&apiKey=API_KEY

sample [0] .articles.count的索引错误超出范围

我正在尝试使用我解析的数据填充标签。我试过了,它只返回1个单元格。

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

ViewController.swift

import UIKit

struct News: Decodable {

    let articles: [Article]

    struct Article: Decodable {
        let title: String?
        let urlToImage: String?
        let description: String?
    }
}
class ViewController: UIViewController {

    @IBOutlet weak var table: UITableView!

    var sample = [News]()

    override func viewDidLoad() {
        super.viewDidLoad()
        // Do any additional setup after loading the view.
        getJson()

        table.delegate = self
        table.dataSource = self

    }

    func getJson() {
        let urlString = "https://newsapi.org/v2/top-headlines?country=us&category=business&apiKey=e07d26ea273d41e2af174b026aea27b5"

        guard let url = URL(string: urlString) else { return }

        URLSession.shared.dataTask(with: url) { (data, response, error) in
            guard let data = data else { return }

            do {
                self.sample = [try JSONDecoder().decode(News.self, from: data)]
                print(self.sample[0].articles.count)
                for dict in self.sample {
                    for sam in dict.articles {
                        print(sam.title!)
                    }
                }

                DispatchQueue.main.async {
                    //reload tableView data
                    self.table.reloadData()
                }

            } catch let jsonErr {
                print("json error: ", jsonErr)
            }
        }.resume()
    }
}

extension ViewController: UITableViewDataSource, UITableViewDelegate {

    func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
        return sample[0].articles.count
    }

    func tableView(_ tableView: UITableView, heightForRowAt indexPath: IndexPath) -> CGFloat {
        return CGFloat(100)
    }

    func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
        let cell = tableView.dequeueReusableCell(withIdentifier: "TableViewCell") as! TableViewCell
        let json = sample[0].articles[indexPath.row]
        cell.name.text = "\(json.title!)"
        cell.link.text = "\(json.description!)"
        cell.imageUrl.text = "\(json.urlToImage!)"
        return cell
    }


}

1 个答案:

答案 0 :(得分:1)

您正在异步设置QThread: Destroyed while thread is still running Aborted (core dumped) ,将在sample包含任何内容之前调用tableView(_ tableView: UITableView, numberOfRowsInSection section: Int)。 以下更改将防止崩溃。

sample