【问题标题】:pushing data to UITableView is not showing将数据推送到 UITableView 未显示
【发布时间】:2019-04-18 19:58:31
【问题描述】:

我正在尝试将数据从 UIViewController 推送到 UITableView。现在我可以将一条数据推送到单元格,它看起来很好。如果我返回并推送更多数据,我遇到的问题只是覆盖了单元格。而不是去另一个牢房。我已经尝试了这个post 的建议 和self.tableView.reloadData()。这似乎并没有解决我遇到的问题。下面是我写的代码。

class PredictorTableViewController: UITableViewController {
    var predictorTrack = ""
    var firstDriver = ""
    var secondDriver = ""
    var thirdDriver = ""

    var grandPrix = [GrandPrix]()

    override func viewDidLoad() {
        super.viewDidLoad()
        self.grandPrix.append(GrandPrix(granPrix: predictorTrack, firstDriver: firstDriver, secondDriver: secondDriver, thirdDriver: thirdDriver))
        self.tableView.reloadData()
        self.navigationItem.title = "Predictor"
        let backbutton = UIButton(type: .custom)
        backbutton.setTitle(" Back", for: .normal)
        backbutton.setTitleColor(.blue, for: .normal)
        backbutton.addTarget(self, action: #selector(self.backbuttonpressed), for: .touchUpInside)

        self.navigationItem.leftBarButtonItem = UIBarButtonItem(customView: backbutton)
        setupNavBar()

    }

    @objc func backbuttonpressed() {
        dismiss(animated: true, completion: nil)
    }

    func setupNavBar(){
        navigationController?.navigationBar.prefersLargeTitles = true
    }

    // MARK: - Table view data source

    override func numberOfSections(in tableView: UITableView) -> Int {
        // #warning Incomplete implementation, return the number of sections
        return 1
    }

    override func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
        // #warning Incomplete implementation, return the number of rows
        return grandPrix.count
    }

    override func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
     let cell = tableView.dequeueReusableCell(withIdentifier: "cell") as! GrandPrixTableViewCell
        let race = self.grandPrix[indexPath.row]
        // Configure the cell...
        cell.grandPrix.text = race.grandPrix
        cell.firstPostion.text = race.firstDriver
        cell.secondPosition.text = race.secondDriver
        cell.thirdPostion.text = race.thirdDriver

        return cell
    }

下面是准备segue的函数。

override func prepare(for segue: UIStoryboardSegue, sender: Any?) {
    if segue.identifier == "getPredictor" {
        let predictorVC = segue.destination as! UINavigationController
        let vc = predictorVC.topViewController as! PredictorTableViewController
        vc.predictorTrack = TrackTextField.text!
        vc.firstDriver = firstTextField.text!
        vc.secondDriver = secondTextField.text!
        vc.thirdDriver = thirdTextField.text!
    }
}

【问题讨论】:

  • 您是否尝试将 didSet 设置为您在 stackoverflow 问题链接中提到的 grandPrix 变量?试试这个 var grandPrix = [GrandPrix]() { didSet {self.tableView.reloadData()} }。你说你回去,你回去哪里?你解雇了 ViewController 吗?那么您的数据模型可能只有一个元素。需要更多关于 GrandPrix 以及如何填充 [GrandPrix]() 数组的说明。
  • 我已经尝试过 Imrul 并且它仍然会覆盖单元格。所以只显示一条数据。
  • 你回去的时候检查过,[GrandPrix]()数组有多少元素?
  • 它只是显示以下[Racing_Weather.GrandPrix] [Racing_Weather.GrandPrix] [Racing_Weather.GrandPrix]
  • 也许你的数组没有存储以前的数据,当你关闭 VC 时,你的数组变为空。当您关闭 PredictorTableViewController 时,在调试部分使用 po 命令查看 var grandPrix 是否为空。

标签: ios arrays swift tableview


【解决方案1】:

您的问题是,每当您返回到以前的 UIViewConntroller 实例时,PredictorTableViewController 就会从内存中删除,因此与之关联的所有数据也都消失了(grandPrix 数组)。

我可以建议您 3 个解决方案:


第一

grandPrix 数组保留在父 UIViewController 中,并在执行 segue 时将其传递给 PredictorTableViewController

var grandPrix = [GrandPrix]()

...

override func prepare(for segue: UIStoryboardSegue, sender: Any?) {
    if segue.identifier == "getPredictor" {
        let predictorVC = segue.destination as! UINavigationController
        let vc = predictorVC.topViewController as! PredictorTableViewController

        // append new GrandPrix to local array
        self.grandPrix.append(GrandPrix(granPrix: TrackTextField.text!, firstDriver: firstTextField.text!, secondDriver: secondTextField.text!, thirdDriver: thirdTextField.text!)) 

        // important part: pass local data to destination
        vc.grandPrix = self.grandPrix    
    }
}

第二次

PredictorTableViewController 保留为父UIViewCointroller 的强引用,并在需要时手动将PredictorTableViewController 推送到UINavigationController

// Strong lazy reference
lazy var predicatorController: PredicatorTableViewController = {

    // If needed, this can be loaded from a NIB or Storyboard
    return PredicatorTableViewController()
}()

UINavigationController函数之后使用这个调用:

// generate new data for predicatorController and append it to grandPrix array
predicatorController.grandPrix.append(...)

// show predicatorController
self.navigationController?.pushViewController(predicatorController, animated: true)

附:使用此解决方案不要使用 segues。


第三

与第一个建议的想法相同,但grandPrix数组的数据将存储在本地缓存中(例如CoreData数据库)。当您需要访问现有的 GrandPrix 对象并将新的 GrandPrix 对象存储到本地缓存中时,您将不得不编写本地缓存数据检索/存储函数并相应地使用它。


祝你好运:)

【讨论】:

  • 谢谢你,Tomas,这对你有很大帮助。
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2013-04-28
  • 2021-08-28
相关资源
最近更新 更多