问题
I'm trying to run a basic test SwiftUI app for macOS using Core Data, and I'm hitting a problem. When I use this in my view:
@FetchRequest(entity: Note.entity(), sortDescriptors: []) let notes: FetchedResults<Note>
The app crashes with the following errors:
NoteTaker [error] error: No NSEntityDescriptions in any model claim the NSManagedObject subclass 'NoteTaker.Note' so +entity is confused. Have you loaded your NSManagedObjectModel yet ?
CoreData: error: No NSEntityDescriptions in any model claim the NSManagedObject subclass 'NoteTaker.Note' so +entity is confused. Have you loaded your NSManagedObjectModel yet ?
NoteTaker [error] error: +[NoteTaker.Note entity] Failed to find a unique match for an NSEntityDescription to a managed object subclass
CoreData: error: +[NoteTaker.Note entity] Failed to find a unique match for an NSEntityDescription to a managed object subclass
NoteTaker executeFetchRequest:error: A fetch request must have an entity.
Now, if I used the alternate form of FetchRequest, it then works fine though the code is much uglier:
// outside of the view
func getAllNotes() -> NSFetchRequest<Note> {
let request: NSFetchRequest<Note> = Note.fetchRequest()
request.sortDescriptors = []
return request
}
// in the view
@FetchRequest(fetchRequest: getAllNotes()) var notes: FetchedResults<Note>
Also, if I turn this into an iOS app instead, then the entity version of the @FetchRequest works fine.
Any ideas?
回答1:
Use the Storyboard template and then set up the view using SwiftUI in the view controller.
override func viewWillAppear() {
super.viewWillAppear()
let context = (NSApplication.shared.delegate as! AppDelegate).persistentContainer.viewContext
let contentView = ContentView().environment(\.managedObjectContext, context)
view = NSHostingView(rootView: contentView)
}
来源:https://stackoverflow.com/questions/58794088/using-fetchrequestentity-for-swiftui-macos-app-crashes