gpt4 book ai didi

ios - Swift - 在 Controller 之间移动后表为空

转载 作者:行者123 更新时间:2023-11-30 12:35:44 26 4
gpt4 key购买 nike

我正在更新现有的 Objective-C 应用。

有一个结构:应用程序代理- 创建 mainBackgroundView 并使用 UITabBarController 添加 subview

我有一个“选项卡”HistoryViewController:

@objc class HistoryViewController: UIViewController {

override func viewDidLoad() {
super.viewDidLoad()
let historyTableViewController = HistoryTableViewController()
self.view.addSubview(historyTableViewController.view)
}

}

和HistoryTableViewController:

import UIKit

@objc class HistoryTableViewController: UITableViewController {

// Mark: properties

var historyCalls = [HistoryItem]()

// Mark: private methods
private func loadSimpleHistory() {
let hist1 = HistoryItem(personName: "Test", bottomLine: "text", date: "10:47")
let hist2 = HistoryItem(personName: "Test 2", bottomLine: "text", date: "10:47")
let hist3 = HistoryItem(personName: "Test 3", bottomLine: "text", date: "10:47")
historyCalls += [hist1, hist2, hist3]
}




override func viewDidLoad() {
super.viewDidLoad()

self.loadSimpleHistory()

self.tableView.register(UINib(nibName: "HistoryCallTableViewCell", bundle: nil), forCellReuseIdentifier: "HistoryCallTableViewCell")
}

override func didReceiveMemoryWarning() {
super.didReceiveMemoryWarning()
// Dispose of any resources that can be recreated.
}

// 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 historyCalls.count
}


override func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
guard let cell = tableView.dequeueReusableCell(withIdentifier: "HistoryCallTableViewCell", for: indexPath) as? HistoryCallTableViewCell else {
fatalError("Coulnd't parse table cell!")
}

let historyItem = historyCalls[indexPath.row]

cell.personName.text = historyItem.personName
cell.bottomLine.text = historyItem.bottomLine
cell.date.text = historyItem.date


return cell
}

}

当我第一次使用 HistoryViewController 打开导航选项卡时,表格中会显示数据。当我点击表格或切换 navTab 然后返回时,表格不再存在。

当我切换到另一个应用程序然后返回时,表格又出现了。

如何解决这个问题?

谢谢

最佳答案

在viewwillappear中调用数据方法并重新加载表格..

  override func viewWillAppear() {
super.viewWillAppear()
self.loadSimpleHistory()
self.tableview.reloadData()
}

关于ios - Swift - 在 Controller 之间移动后表为空,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42886789/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com