Как удалить элемент в цикле forEach с помощью функции удаления btn для каждого из них. Я использую SwiftUI с основными данными

0

Вопрос

Вот код, если вы не понимаете

struct cartView: View {
        @Environment(\.managedObjectContext) private var viewContext
    
        @FetchRequest(
            sortDescriptors: [], animation: .default) private var products: FetchedResults<Prod>
        
        let columns = [GridItem(.flexible()), GridItem(.flexible())]
        @State var indx = 0
    
        var body: some View {
            NavigationView {
                ScrollView {
                    VStack {
                        LazyVGrid(columns: columns) {
                            ForEach(products, id: \.self) {prod in
                                let prodItems = Product(name: prod.name ?? "Undefined", price: prod.price ?? "Undefined", type: "type", brand: prod.brand ?? "Undefined", images: [prod.image!,""])
                                
                                    ZStack {
                                    Cells(product: prodItems)
                                    // I want the button below delete the item of the 
                                    // button pressed with the function below
                                    Button(action: {}) {
                                        Image(systemName: "xmark.bin.circle")
                                            .resizable()
                                            .frame(width: 30, height: 30)
                                            .foregroundColor(.red)
                                            .background(.black)
                                            .clipShape(RoundedRectangle(cornerRadius: 20))
                                            .offset(x: 60, y: 45)
                                    }
                                }
                            }
                        }
                    }
                }
                .navigationTitle("Cart")
            }
        }
        
        private func deleteItems(offsets: IndexSet) {
            withAnimation {
                offsets.map { products[$0] }.forEach(viewContext.delete)
    
                do {
                    try viewContext.save()
                } catch {
                    let nsError = error as NSError
                    fatalError("Unresolved error \(nsError), \(nsError.userInfo)")
                }
            }
        }
}

итак, вопрос здесь в кнопке в цикле forEach для удаления элемента, который пользователь нажал на кнопку, и я знаю, как это сделать, но чего я не знаю, так это как получить индекс элемента и передать его в функцию.

core-data swift swiftui
2021-11-14 09:37:14
1

Лучший ответ

0

На самом деле вам не нужен индекс, если вы выполняете инструкцию по удалению из своего цикла, так как ваш NSManagedObjectContext экземпляр имеет delete(_:) метод, который принимает сам объект. Это изменение будет распространяться через ваш @FetchRequest объект автоматически ваше представление SwiftUI обновится, чтобы показать коллекцию без теперь удаленного объекта.

Таким образом, ваше действие с кнопкой становится:

Button(action: {
  viewContext.delete(prod)
}) {
  Image(systemName: ...)
  // etc.
}

Обратите внимание, что, хотя вы сразу увидите эффект, удаление будет сохраняться в памяти только до тех пор, пока вы не позвоните save в контексте управляемого объекта.

В моих приложениях CoreData я обычно сохраняю свои изменения отдельно, например, когда приложение собирается перейти в фоновый режим. Но если вы хотите запустить сохранение сразу после удаления объекта, это достаточно просто:

Button(action: {
  viewContext.delete(prod)
  try? viewContext.save()
}) {
  Image(systemName: ...)
  // etc.
}

ПРИМЕЧАНИЕ: документация для NSManagedObjectContext.save() говорит, что вы должны проверить hasChanges свойство перед попыткой сохранения, но, поскольку вы только что внесли изменения в строку выше, в данном конкретном примере это необязательно.

2021-11-14 16:37:10

большое спасибо, это работает, вы действительно помогли мне!
Fovu

На других языках

Эта страница на других языках

Italiano
..................................................................................................................
Polski
..................................................................................................................
Română
..................................................................................................................
한국어
..................................................................................................................
हिन्दी
..................................................................................................................
Français
..................................................................................................................
Türk
..................................................................................................................
Česk
..................................................................................................................
Português
..................................................................................................................
ไทย
..................................................................................................................
中文
..................................................................................................................
Español
..................................................................................................................
Slovenský
..................................................................................................................