UITableView 不使用 SwiftyJSON 和 Alamofire 加载数据

UITableView not loading data with SwiftyJSON and Alamofire

我正在尝试解析 json 并将其加载到 CustomTable 中,我的 json 解析成功但无法加载 UI 中的数据,我尝试添加测试数据, 并显示。所以我想这与范围界定有关。我试过在同一个问题上使用其他答案,但它仍然不适合我

import UIKit
import Alamofire
import SwiftyJSON

class NewsViewController: UIViewController, 
   UITableViewDelegate, UITableViewDataSource {

     @IBOutlet weak var tableView: UITableView!



    var newsPosts = [NewsPost]()

    override func viewDidLoad() {
        super.viewDidLoad()

        tableView.delegate = self
        tableView.dataSource = self

        getNewsPost()


    }

    func numberOfSections(in tableView: UITableView) -> Int {
        return 1
    }

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

        let post = newsPosts[indexPath.row]

        if let cell = tableView.dequeueReusableCell(withIdentifier: "NewsCell") as? NewsPostCell{
        cell.configureCell(post: post)
        return cell
    }else{
        let cell = NewsPostCell()
        cell.configureCell(post: post)
        return cell
    }
}


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


func getNewsPost(){
    Alamofire.request(URL_BASE + NEWS_URL).responseJSON { response in


        let json = JSON(data: response.data!)

        if let dict = json.dictionaryObject{
            if let result = dict["data"] as? [NSDictionary]{
                for data in result{
                    guard let title = data["title"] as? String else{
                        return print("title is nil")
                    }
                    guard let href = data["href"] as? String else{
                        return print("href is nil")
                    }
                        guard let image = data["image"] as? String else{
                            return print("image is nil")
                        }
                        guard let content = data["content"] as? String else{
                            return print("content is nil")
                        }
                        guard let _ = data["timestamp"] as? String else{
                            return print("timestamp is nil")
                        }
                        guard let type = data["type"] as? String else{
                            return print("type is nil")
                        }

                        print(type)

                        let post = NewsPost(title: title, href: href, 
                        image: image, timestamp: 
                        "1 day ago", content: content, type: type)

                        self.newsPosts.append(post)
                    }
                    self.tableView.reloadData()
                }
            }
        }
    }


}

我想问题出在您调用 gettingNewPost 函数时。 reloadData() 函数在 didLoad 之后立即被调用,也许您在调用该函数填充 table 时甚至还没有获取数据。您是否尝试登录 cellForRow 函数以查看是否正在尝试访问 nil 数组?

您应该在重新加载数据之前测试您的 tableview 是否已初始化:

import UIKit
import Alamofire
import SwiftyJSON

class NewsViewController: UIViewController, 
   UITableViewDelegate, UITableViewDataSource {

     @IBOutlet weak var tableView: UITableView!



    var newsPosts = [NewsPost]()

    override func viewDidLoad() {
        super.viewDidLoad()

        tableView.delegate = self
        tableView.dataSource = self

        getNewsPost()


    }

    func numberOfSections(in tableView: UITableView) -> Int {
        return 1
    }

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

        let post = newsPosts[indexPath.row]

        if let cell = tableView.dequeueReusableCell(withIdentifier: "NewsCell") as? NewsPostCell{
        cell.configureCell(post: post)
        return cell
    }else{
        let cell = NewsPostCell()
        cell.configureCell(post: post)
        return cell
    }
}


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


func getNewsPost(){
    Alamofire.request(URL_BASE + NEWS_URL).responseJSON { response in


        let json = JSON(data: response.data!)

        if let dict = json.dictionaryObject{
            if let result = dict["data"] as? [NSDictionary]{
                for data in result{
                    guard let title = data["title"] as? String else{
                        return print("title is nil")
                    }
                    guard let href = data["href"] as? String else{
                        return print("href is nil")
                    }
                        guard let image = data["image"] as? String else{
                            return print("image is nil")
                        }
                        guard let content = data["content"] as? String else{
                            return print("content is nil")
                        }
                        guard let _ = data["timestamp"] as? String else{
                            return print("timestamp is nil")
                        }
                        guard let type = data["type"] as? String else{
                            return print("type is nil")
                        }

                        print(type)

                        let post = NewsPost(title: title, href: href, 
                        image: image, timestamp: 
                        "1 day ago", content: content, type: type)

                        self.newsPosts.append(post)
                    }
                    if self.tableView != nil {
                        self.tableView.reloadData()
                    }
                }
            }
        }
    }


}

我终于找到问题了,其中一个守卫是return nil,所以它阻止了其他人的执行,所以我从使用守卫改为下面的

let title = data["title"] as? String ?? ""
let href = data["href"] as? String ?? ""
let image = data["image"] as? String ?? ""
let content = data["content"] as? String ?? ""
let type = data["type"] as? String ?? ""