我有一个带有 NSFetchedResultsController
的 tableView
!我已经完全完成了 NSFetchedResultsController
的委托(delegate)方法并且工作完美!我的问题线是呈现一个 UIAlertController
。 UIAlertController
在 tableView
上运行良好,但在 UISearchController
内部不起作用。我试图删除 UISearchController 内的对象。当我按下删除按钮时,Xcode 给出如下错误:
这是我的 commitEditingStyle
方法和 UIAlertController
、UIAlertAction
的 handler
的代码:
`//覆盖以支持编辑 TableView 。 覆盖 func tableView(tableView: UITableView, commitEditingStyle editoringStyle: UITableViewCellEditingStyle, forRowAtIndexPath indexPath: NSIndexPath) { 如果编辑style==.删除{
let itemToDelete:Manager = self.fetchedResultsController.objectAtIndexPath(indexPath) as! Manager
prepareForDelete(itemToDelete)
// Delete the row from the data source
//tableView.deleteRowsAtIndexPaths([indexPath], withRowAnimation: .Fade)
} else if editingStyle == .Insert {
// Create a new instance of the appropriate class, insert it into the array, and add a new row to the table view
}
}
// Delete Action
var itemsToDelete:Manager!
// Delete function
私有(private)函数prepareForDelete(托管对象:管理器){
//
self.itemsToDelete = managedObject
// Alert
let alert:UIAlertController = UIAlertController(title: "Warning!", message: "Do you want to delete this note?", preferredStyle: UIAlertControllerStyle.Alert)
// Actions
let deleteAction:UIAlertAction = UIAlertAction(title: "Delete", style: UIAlertActionStyle.Destructive, handler: deleteHandler)
// Actions
let cancelAction:UIAlertAction = UIAlertAction(title: "Cancel", style: UIAlertActionStyle.Cancel, handler: nil)
// Add actions to the alert
alert.addAction(deleteAction)
alert.addAction(cancelAction)
// Present alert
self.presentViewController(alert, animated: true, completion: nil)
}
func deleteHandler(alert:UIAlertAction) -> Void {
// Delete from the moc
if let delete = self.itemsToDelete {
self.managedObjectContext.deleteObject(delete)
do {
// Save changes
try self.managedObjectContext.save()
} catch {
}
self.itemsToDelete = nil
}
}`
如何禁用UIAlertController
?我不需要内部警报
UISearchController
。因为这个函数在 UISearchController
感谢您的关注!
最佳答案
您可以检查您的搜索 Controller 是否处于事件状态(我假设您在 View Controller 中引用了您的搜索 Controller )。
将此添加到 prepareForDelete
的开头:
guard !searchController.active else { return }
该代码检查搜索 Controller 是否未激活,如果是,则不会执行任何代码。
关于swift - "Swift Core Data"和 UISearchController,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35809386/