- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在更新 coredata 的某些部分,并且我希望 NSFetchedResultsController 自动重新加载包含所有动画的表格 View 。我正在更改用于对 TableView 进行排序的 coredata 元素。我通过在单元格上向右滑动,然后将该特定 tableviewcell 的priorityNumber更改为零来完成此操作,以便任务转到底部和其他一些事情。我希望表格重新加载但带有动画。现在我只是在做 tableView.reload() 但它不能正常工作。
我想看到单元格移动到设备底部的动画。任何帮助将不胜感激!
代码如下:我对 coreData 所做的更改:
func tableView(_ tableView: UITableView,
leadingSwipeActionsConfigurationForRowAt indexPath: IndexPath) -> UISwipeActionsConfiguration?
{
let closeAction = UIContextualAction(style: .normal, title: "✓", handler: { (ac:UIContextualAction, view:UIView, success:(Bool) -> Void) in
//???
self.fetchedResultsController.object(at: indexPath).sTaskCompleted = !(self.fetchedResultsController.object(at: indexPath).sTaskCompleted)
if ( self.fetchedResultsController.object(at: indexPath).sTaskCompleted)
{
print("Completed")
//Change priority number to 0 after saving their current priority number in previousPN
//Change priority circle color
//Change background of the cell to something else
self.fetchedResultsController.object(at: indexPath).sPreviousPN = self.fetchedResultsController.object(at: indexPath).sPriorityNumber
self.fetchedResultsController.object(at: indexPath).sPriorityNumber = 0
self.fetchedResultsController.object(at: indexPath).cellbackgroundColor = UIColor(red:0.93, green:0.91, blue:0.91, alpha:1.0)
self.fetchedResultsController.object(at: indexPath).previousPriorityColor = self.fetchedResultsController.object(at: indexPath).sPriorityColor
self.fetchedResultsController.object(at: indexPath).sPriorityColor = .clear
var error: NSError?
do {
// Save The object
try self.moContext.save()
print("SAVED")
} catch let error1 as NSError {
error = error1
}
DispatchQueue.main.asyncAfter(deadline: .now() + 0.3, execute: {
UIView.transition(with: tableView,
duration: 0.15,
options: .transitionCrossDissolve,
animations: { self.tableView.reloadData() })
})
} else {
print("InCompleted")
self.fetchedResultsController.object(at: indexPath).sPriorityNumber = self.fetchedResultsController.object(at: indexPath).sPreviousPN
self.fetchedResultsController.object(at: indexPath).cellbackgroundColor = .white
self.fetchedResultsController.object(at: indexPath).sPriorityColor = self.fetchedResultsController.object(at: indexPath).previousPriorityColor
var error: NSError?
do {
// Save The object
try self.moContext.save()
print("SAVED")
} catch let error1 as NSError {
error = error1
}
DispatchQueue.main.asyncAfter(deadline: .now() + 0.3, execute: {
UIView.transition(with: tableView,
duration: 0.15,
options: .transitionCrossDissolve,
animations: { self.tableView.reloadData() })
})
}
success(true)
})
closeAction.backgroundColor = UIColor(red:0.18, green:0.87, blue:0.65, alpha:1.0)
return UISwipeActionsConfiguration(actions: [closeAction])
}
现在如何使用 FRC 委托(delegate)方法 (.update) 用适当的动画刷新 tableView。
最佳答案
TableView Controller 需要符合 NSFetchedResultsControllerDelegate 并实现其委托(delegate)方法。如果配置正确,获取的结果 Controller 将监视托管对象上下文的更改,并调用适当的委托(delegate)方法以使用动画更新 TableView 。
class TaskTableViewController: UITableViewController, NSFetchedResultsControllerDelegate {
var fetchedResultsController: NSFetchedResultsController<Task>!
override func viewDidLoad() {
super.viewDidLoad()
configureFetchedResultsController()
}
func configureFetchedResultsController() {
if fetchedResultsController == nil {
// 1. Get fetch request
let fetchRequest: NSFetchRequest<Task> = Task.fetchRequest()
// 2. Add sort descriptors
fetchRequest.sortDescriptors = [NSSortDescriptor(key: "sPriorityNumber", ascending: false)]
// 3. Configure the FRC
fetchedResultsController = NSFetchedResultsController<Task>(fetchRequest: fetchRequest, managedObjectContext: CoreDataStack.context, sectionNameKeyPath: nil, cacheName: nil)
// 4. Set the FRC delegate as self
fetchedResultsController.delegate = self
}
// 5. Tell the FRC to start watching the MOC for changes
do {
try fetchedResultsController.performFetch()
} catch {
NSLog("Error starting fetched results controller \(error)")
}
}
// FRC delegate methods
func controller(_ controller: NSFetchedResultsController<NSFetchRequestResult>,
didChange anObject: Any,
at indexPath: IndexPath?,
for type: NSFetchedResultsChangeType,
newIndexPath: IndexPath?) {
switch type {
case .insert:
guard let newIndexPath = newIndexPath else { return }
tableView.insertRows(at: [newIndexPath], with: .automatic)
case .delete:
guard let indexPath = indexPath else { return }
tableView.deleteRows(at: [indexPath], with: .fade)
case .move:
tableView.reloadData()
case .update:
guard let indexPath = indexPath else { return }
tableView.reloadRows(at: [indexPath], with: .automatic)
}
}
func controller(_ controller: NSFetchedResultsController<NSFetchRequestResult>,
didChange sectionInfo: NSFetchedResultsSectionInfo,
atSectionIndex sectionIndex: Int,
for type: NSFetchedResultsChangeType) {
switch type {
case .delete:
tableView.deleteSections(IndexSet(integer: sectionIndex), with: .automatic)
case .insert:
tableView.insertSections(IndexSet(integer: sectionIndex), with: .automatic)
default:
break
}
}
}
关于ios - 如何使用 NSFetchedResultsController 更新 tableview 内容,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48254060/
我正在尝试使用具有混合语言数据的 FRC,并希望有一个部分索引。 从文档看来您应该能够覆盖 FRC - (NSString *)sectionIndexTitleForSectionName:(NSS
使用等效的 NSFetchRequest 重新创建 NSFetchedResultsController 时,为什么 [NSFetchedResultsController PerformFetch:
我正在尝试起草一个可重复使用的类,该类基本上可重复用于具有几乎相同实现的多个实体。基本上我将有几个 UIViewController,每个都包含 UIView,其中包含 UITableView 以及由
我有一个 iPhone 和一个 Android 应用程序。在 iPhone 上,我使用 NSFetchedResultsController 来管理我的 UITableView 的数据。目前我有很多数
NSFetchedResultsController 监视对正在跟踪的整个托管对象的更改。每当在当前上下文中修改任何属性时,例如 – controller:didChangeObject:atInde
自 1 个月以来,我一直在使用 NSFetchedResultsController 构建应用程序,并在 3.1.2 SDK 上测试该应用程序。问题是我一直在我的应用程序中到处使用 NSFetched
我有一个人物和宠物的数据库,具有一对多关系 人宠物 姓名 姓名 宠物>主人 我正在使用由核心数据支持的 UITableView 和 nsfetchedresultscontroller 来显示宠物列表
我有一个 NSFetchedResultsController,它在 TableView 中显示项目列表,包括关联实体的计数。当为此关联添加对象时(使用 addXXXObject),不会调用回调来通知
花了几个小时后,我发现无法在以下文章中由 SQLite 支持的 NSFetchedResultsController 中进行自定义排序。 NSFetchedResultsController cust
我设置了一个 NSFetchedResultsController 来填充 UITableView,基于我的“主”NSManagedObjectContext。 在计时器中,我不断地将对象添加到单独的
在我的应用程序中,我需要循环遍历核心数据中的所有实体,并且我正在使用 NSFetchedresultcontroller。 我现在正在这样做: NSArray *tempArray = [[NSArr
我正在开发我的第一个核心数据支持的应用程序,但无法弄清楚如何正确设置 NSFetchedResultsController。我有两个实体: /-----------\ /--------
我正在使用 NSFetchedResultsController 在 TableView 中显示项目: - (NSInteger)numberOfSectionsInTableView:(UITabl
我将 NSFetchedResultsController 放入我的代码中,这样我就可以对 TableView 数据进行很好的自动分段。 所以我正在运行测试以确保一切正常。我的持久存储中有一个 Boo
我如何使用带有翻译后的排序键和sectionKeyPath的NSFetchedResultsController? 问题:我在数据库中的属性“type”中有 ID,例如 typeA、typeB、typ
大家好 我的 CoreData 驱动应用程序有多个来自同一存储的数据 View ,并且全部使用 NSFetchedResultsController。目前,它们的 NSFetchedResultsCo
我想使用使用 bool 值设置的不同谓词从 NSFetchedResultsController 重新获取数据。如何刷新 NSFetchedResultsController 以获取一组新数据? -
核心数据在 NSManagedObjectContext 类中提供了“executeFetchRequest”方法,我们可以使用该方法从表中获取数据并以任何需要的方式使用它。 现在还有另一种方法,即使
我正在编写一个应用程序,一个屏幕上有两个表格。左表是文件夹列表,右表显示文件列表。当点击左侧的一行时,右侧表格将显示属于该文件夹的文件。 我正在使用 Core Data 进行存储。当文件夹的选择发生变
我有一个由 NSFetchedResultsController 管理的 TableView 。但是,我在查找或创建操作时遇到问题。当用户点击表格 View 的底部时,我正在向服务器查询另一批内容。如
我是一名优秀的程序员,十分优秀!