我遇到了NSFetchedResultsViewController的问题。这是我的设置。我的应用程序rootViewController是一个TabBarController。连接到我的UITabBarController是两个视图控制器(所以我有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)!)
}
}
非常感谢任何帮助。我没有想法。
答案 0 :(得分:0)
您的代码似乎是正确的,但我宁愿为您提供NSFetchResultsController,它通常是如何在代码中实现的。您需要在委托中实现至少三种方法
controllerWillChangeContent:
controllerDidChangeContent:
controller:DidChangeObject:atIndexPath:forChangeType:newIndexPath
希望这会有所帮助。
P上。 S.您是否确定每次打印您的值时都会调用单元格的方法。尝试设置断点或else子句去检查这个。另外,我会重新检查单元的标识符和出口的连接