Список SwiftUI не обновляется при обновлении основного свойства данных в другом представлении ⇐ IOS
-
Гость
Список SwiftUI не обновляется при обновлении основного свойства данных в другом представлении
@State var document: [ScanDocument] = [] функция загрузкиДокументов() { охранник пусть appDelegate = UIApplication.shared.delegate как? AppDelegate еще { возвращаться } пусть управляемыйКонтекст = appDelegate.persistentContainer.viewContext пусть fetchRequest = NSFetchRequest(имя объекта: «СканДокумент») делать { документы = попробуйте ManagedContext.fetch(fetchRequest) как! [Сканировать документ] print(documents.compactMap({$0.name})) } поймать пусть ошибку как NSError { print("Не удалось получить. \(error), \(error.userInfo)") } } В первом представлении:
.onAppear(){ self.loadDocuments() } Теперь я настаиваю на детальном просмотре одного объекта:
NavigationLink(назначение: RenameDocumentView(документ: документы[selectedDocumentIndex!]), isActive: $pushActive) { Текст("") }.скрытый() В RenameDocumentView:
var документ: ScanDocument Также есть одна функция для обновления имени документа:
func renameDocument() { Guard !fileName.isEmpty еще {возврат} имя_документа = имя_файла пытаться? self.moc.save() печать (имя файла) self.presentationMode.wrappedValue.dismiss() } Весь этот код работает. Этот оператор печати всегда печатает обновленное значение:
print(documents.compactMap({$0.name})) Вот код списка в главном представлении:
List(documents, id: \.id) { элемент в ZStack { DocumentCell (документ: элемент) } } Но где пользователь возвращается на предыдущий экран. В списке показаны старые данные. Если я перезапущу приложение, оно покажет новые данные.
Любое подталкивание в новом направлении будет полезно.
Здесь есть аналогичный вопрос: представление списка SwiftUI не обновляется после обновления объекта основных данных в другом представлении, но на него нет ответов.
@State var document: [ScanDocument] = [] функция загрузкиДокументов() { охранник пусть appDelegate = UIApplication.shared.delegate как? AppDelegate еще { возвращаться } пусть управляемыйКонтекст = appDelegate.persistentContainer.viewContext пусть fetchRequest = NSFetchRequest(имя объекта: «СканДокумент») делать { документы = попробуйте ManagedContext.fetch(fetchRequest) как! [Сканировать документ] print(documents.compactMap({$0.name})) } поймать пусть ошибку как NSError { print("Не удалось получить. \(error), \(error.userInfo)") } } В первом представлении:
.onAppear(){ self.loadDocuments() } Теперь я настаиваю на детальном просмотре одного объекта:
NavigationLink(назначение: RenameDocumentView(документ: документы[selectedDocumentIndex!]), isActive: $pushActive) { Текст("") }.скрытый() В RenameDocumentView:
var документ: ScanDocument Также есть одна функция для обновления имени документа:
func renameDocument() { Guard !fileName.isEmpty еще {возврат} имя_документа = имя_файла пытаться? self.moc.save() печать (имя файла) self.presentationMode.wrappedValue.dismiss() } Весь этот код работает. Этот оператор печати всегда печатает обновленное значение:
print(documents.compactMap({$0.name})) Вот код списка в главном представлении:
List(documents, id: \.id) { элемент в ZStack { DocumentCell (документ: элемент) } } Но где пользователь возвращается на предыдущий экран. В списке показаны старые данные. Если я перезапущу приложение, оно покажет новые данные.
Любое подталкивание в новом направлении будет полезно.
Здесь есть аналогичный вопрос: представление списка SwiftUI не обновляется после обновления объекта основных данных в другом представлении, но на него нет ответов.
Мобильная версия