gpt4 book ai didi

ios - NSFetchedResultsController 返回行并填充表格,但表格单元格标签消失

转载 作者:可可西里 更新时间:2023-10-31 23:35:50 24 4
gpt4 key购买 nike

我遇到了 NSFetchedResultsViewController 的问题。这是我的设置。我的应用程序 rootViewController 是一个 TabBarController。连接到我的 UITabBarController 的是两个 View Controller (所以我有 2 个选项卡)。与每个选项卡关联的 UIViewControllers 都有容器,我在其中嵌入了另一个 UIViewController。这些 UIViewControllers 之一有一个 UITableView,我试图用来自 CoreData 的数据填充它。因此,为了填充 UITableView,我使用了 NSFetchedResultsViewController。

这是我的奇怪问题。如果我将带有 UITableView/NSFetchedResultsController 的 UIViewController 作为第一个选项卡,以便在应用程序加载时首先显示它,一切都很好,我在 tableview 中看到了预期的 3 行数据(我在每个自定义中设置了两个标签表格单元格)。

Labels visible for each row when on first tab

但是,如果我将 ViewController 设置为第二个选项卡,启动应用程序,查看我的第一个选项卡,然后点击我的 tableview 所在的第二个选项卡,将创建 3 行,但我看不到标签,只有一个带有披露指示符的空白行。

Labels disappear, but the rows are still created when on second tab

NSFectchedResultsController 似乎工作正常,因为即使在单元格标签丢失的情况下,但创建了行,我注销了应该显示的值,并打印了值,所以我的 managedobject 具有值.

以前我没有使用 CoreData,只是用内存中的简单对象填充表格,在选项卡之间点击时一切正常……数据总是出现。我在实现 fetchedResultsController 后才开始看到这个问题。

这是我的代码:

class OrderListViewController: UIViewController, UITableViewDelegate, UITableViewDataSource, NSFetchedResultsControllerDelegate {

@IBOutlet weak var searchBar: UISearchBar!
@IBOutlet weak var tableView: UITableView!

var delegate: OrderListViewControllerDelegate?

private lazy var fetchedResultsController: NSFetchedResultsController = {
let request = NSFetchRequest(entityName: "ListOrder")
let dateSort = NSSortDescriptor(key: "statusSubmittedAt", ascending: true)
request.sortDescriptors = [dateSort]

let pred = NSPredicate(format: "(statusBuilt == %@ and statusCancelled == %@ and statusComplete == %@ and statusSubmitted == %@)", NSNumber(bool: false), NSNumber(bool: false), NSNumber(bool: false), NSNumber(bool: true))
request.predicate = pred

let moc = (UIApplication.sharedApplication().delegate as? AppDelegate)!.managedObjectContext
let controller = NSFetchedResultsController(fetchRequest: request, managedObjectContext: moc, sectionNameKeyPath: nil, cacheName: nil)
controller.delegate = self

return controller
}()

override func viewDidLoad() {
super.viewDidLoad()

// Do any additional setup after loading the view.
do {
try fetchedResultsController.performFetch()
} catch {
fatalError("Failed to initialize FetchedResultsController: \(error)")
}
}

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

func numberOfSectionsInTableView(tableView: UITableView) -> Int {
return fetchedResultsController.sections!.count
}

func tableView(tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
let sections = fetchedResultsController.sections! as [NSFetchedResultsSectionInfo]
let sectionInfo = sections[section]
return sectionInfo.numberOfObjects
}

func tableView(tableView: UITableView, cellForRowAtIndexPath indexPath: NSIndexPath) -> UITableViewCell {
let cell = (tableView.dequeueReusableCellWithIdentifier("OrderListTableViewCell", forIndexPath: indexPath) as? OrderListTableViewCell)!

// Configure the cell...
let order = (fetchedResultsController.objectAtIndexPath(indexPath) as? ListOrder)!

// Update Cell
if let userDisplayName = order.userDisplayName {
print(userDisplayName) //prints correct value to console
cell.orderName.text = userDisplayName
}

if let placementDescription = order.tagPlacementDescription {
cell.orderName.text = cell.orderName.text! + " - \(placementDescription)"
print(placementDescription) //prints correct value to console

}

if let orderTime = order.statusSubmittedAt {
cell.orderTime.text = String.stringTimeFromDate(orderTime)
}

return cell
}


func tableView(tableView: UITableView, didSelectRowAtIndexPath indexPath: NSIndexPath) {

self.delegate?.didSelectOrder(self, order:(fetchedResultsController.objectAtIndexPath(indexPath) as? ListOrder)!)
}
}

非常感谢任何帮助。我没主意了。

最佳答案

你的代码似乎是正确的,但我宁愿让你按照通常在代码中实现的方式来制作你的 NSFetchResultsController。您需要在委托(delegate)中至少实现三个方法

  1. controllerWillChangeContent:
  2. controllerDidChangeContent:
  3. controller:DidChangeObject:atIndexPath:forChangeType:newIndexPath

希望这对您有所帮助。

P. S. 您确定每次调用单元格方法时都会打印您的值吗?尝试设置断点或 else-clause 去检查这个。此外,我会重新检查电池和 socket 连接的标识符

关于ios - NSFetchedResultsController 返回行并填充表格,但表格单元格标签消失,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38473716/

24 4 0