我正在创建一个新应用程序,并且在单击相应的 tableView 单元格时需要帮助以获取我的核心数据实体以更新字段。
我试过用谷歌搜索错误和类似的错误,但我能找到的一切都在 Objective-c 或旧版本的 swift 中。我正在使用迅速。我也在使用 NSFetchedResultsController 来获取数据。
这是我的 tableView 所做的 selectRowAt
override func tableView(_ tableView: UITableView, didSelectRowAt indexPath: IndexPath) {
let item = fetchedRC.object(at:indexPath)
/*if item.isComplete {
item.setValue(false, forKey: "isComplete")
//item.isComplete = false
} else {
item.setValue(true, forKey: "isComplete")
//item.isComplete = true
}*/
item.isComplete.toggle()
do {
try context.save()
tableView.reloadRows(at: [indexPath], with: .automatic)
} catch let error as NSError {
print("Could not save. \(error.localizedDescription)")
}
}
当用户单击单元格时,我希望IsComplete
根据它是真还是假来切换它的值。但它实际上所做的是在 if 语句的两种情况下调用“setValue”时崩溃。错误信息是:
*** 由于未捕获的异常“NSInvalidArgumentException”而终止应用程序,原因:“-[__NSCFNumber caseInsensitiveCompare:]:无法识别的选择器发送到实例 0x9321d02e963b75fc”
编辑:我相信这就是声明 isComplete 的地方
extension Item {
@nonobjc public class func fetchRequest() -> NSFetchRequest<Item> {
return NSFetchRequest<Item>(entityName: "Item")
}
@NSManaged public var name: String?
@NSManaged public var isComplete: Bool
@NSManaged public var list: List?
}
和 DidSet:
var detailedList: List! {
didSet {
}
}
请求和排序
let request = Item.fetchRequest() as NSFetchRequest<Item>
request.predicate = NSPredicate(format: "list = %@", parentObj)
let sort = NSSortDescriptor(key: #keyPath(Item.isComplete), ascending: true, selector: #selector(NSString.caseInsensitiveCompare(_:)))
request.sortDescriptors = [sort]
do {
fetchedRC = NSFetchedResultsController(fetchRequest: request, managedObjectContext: context, sectionNameKeyPath: nil, cacheName: nil)
try fetchedRC.performFetch()
self.tableView.reloadData()
} catch let error as NSError{
print(error.localizedDescription)
}
fetchedRC.delegate = self