【发布时间】:2019-10-21 12:07:21
【问题描述】:
我正在尝试使用 iOS 13 中内置的一些新差异类以及 Core Data。我遇到的问题是controllerdidChangeContentWith 没有按预期工作。它传递给我一个快照引用,它是对一个
NSDiffableDataSourceSnapshot<Section, NSManagedObjectID>
意思是我得到了已更改的部分/对象 ID 的列表。
这部分效果很好。但是当您在集合视图中找到差异时,问题就来了。在 WWDC 视频中他们高兴地打电话
dataSource.apply(snapshot, animatingDifferences: true)
一切都很神奇,但在实际 API 中并非如此。
在我最初的尝试中,我尝试了这个:
resolvedSnapshot.appendItems(snapshot.itemIdentifiersInSection(withIdentifier: section).map {
controller.managedObjectContext.object(with: $0 as! NSManagedObjectID) as! Activity
}, toSection: .all)
这适用于填充单元格,但如果单元格上的数据发生更改(即单元格标题),则永远不会重新加载特定单元格。我查看了快照,看来问题只是我引用了这些活动对象,因此它们都同时更新(意味着旧快照中的活动等同于新快照中的活动,所以哈希值相等。)
我当前的解决方案是使用一个包含我的所有 Activity 类变量的结构,但这会将它与 CoreData 断开连接。所以我的数据源变成了:
var dataSource: UICollectionViewDiffableDataSource<Section, ActivityStruct>
这样快照实际上得到了两个不同的值,因为它有两个不同的对象要比较。这行得通,但似乎远非优雅,这就是我们的本意吗?还是它现在只是处于破碎状态? WWDC 视频似乎暗示它不应该需要所有这些额外的样板文件。
【问题讨论】:
标签: core-data uicollectionview nsfetchedresultscontroller