Jak usunąć element w pętli forEach za pomocą funkcji usuwania btn dla każdego z nich. Używam SwiftUI z podstawowymi danymi

0

Pytanie

Oto kod, jeśli nie rozumiesz

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)")
                }
            }
        }
}

więc pytanie tutaj w przycisku w pętli forEach, aby usunąć element, który użytkownik kliknął przycisk i wiem, jak to zrobić, ale czego nie wiem, to jak zdobyć indeks elementu i go przekazać do funkcji.

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

Najlepsza odpowiedź

0

W rzeczywistości nie potrzebujesz indeks, jeśli wykonujesz instrukcje usuwania ze swojego cyklu, tak jak twój NSManagedObjectContext wystąpienie ma delete(_:) metoda, która ma sam obiekt. Zmiana ta będzie rozprzestrzeniać się za pośrednictwem @FetchRequest obiekt jest automatycznie twój pomysł SwiftUI zostanie zaktualizowany, aby pokazać kolekcję teraz bez zdalnego obiektu.

W ten sposób, twoja akcja z przyciskiem staje się:

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

Należy zwrócić uwagę, że choć od razu widać efekt, usuwanie będą zapisywane w pamięci tylko do momentu, dopóki nie zadzwoni save w kontekście zarządzanego obiektu.

W moich aplikacjach CoreData zwykle zapisuję swoje zmiany oddzielnie, na przykład, gdy aplikacja będzie przejść w tle. Ale jeśli chcesz uruchomić zapisywanie natychmiast po usunięciu obiektu, to wystarczy:

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

UWAGA: dokumentacja NSManagedObjectContext.save() mówi, że trzeba sprawdzić hasChanges właściwość przed próbą zachowania, ale, ponieważ właśnie wprowadzono zmiany w wierszu powyżej, w tym konkretnym przykładzie jest to opcjonalne.

2021-11-14 16:37:10

dziękuję bardzo, to działa, naprawdę mi pomógł!
Fovu

W innych językach

Ta strona jest w innych językach

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