我正在尝试将数据从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
}
下面是准备进行搜索的功能。
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!
}
}
答案 0 :(得分:1)
您的问题是,每当您返回到UIViewConntroller
的上一个PredictorTableViewController
实例时,都会从内存中删除该实例,因此与之关联的所有数据也都消失了(grandPrix
数组)。
我可以建议您3种解决方案:
在执行segue时,将grandPrix
数组保留在父UIViewController
中,并传递给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)
P.S。使用此解决方案时,请勿使用segues。
第三方
与第一个建议的想法相同,但是grandPrix
数组的数据将存储在本地缓存中(例如CoreData数据库)。您将必须编写本地缓存数据检索/存储功能,并在需要访问现有的并将新的GrandPrix对象存储到本地缓存中时相应地使用它。
祝你好运:)