swiftui - 过滤列表时SwiftUI .onDelete错误的索引
问题描述
这是我的代码:
import SwiftUI
struct IngredientsList: View {
@EnvironmentObject var ingredientsStore: IngredientEdit
@State private var searchText = ""
var searchResults: [Ingredient] {
if searchText.isEmpty {
return ingredientsStore.items
} else {
return ingredientsStore.items.filter {
$0.name.lowercased().contains(searchText.lowercased()) }
}
}
var body: some View {
NavigationView {
List {
ForEach (searchResults) { ingredient in
NavigationLink (destination: IngredientDetail(ingredient: ingredient)) {
IngredientRow(ingredient: ingredient)
}
}
.onDelete(perform: deleteItems)
}
.searchable(text: $searchText, placement: .navigationBarDrawer(displayMode: .automatic))
.navigationTitle("Ingredients")
}
.navigationViewStyle(StackNavigationViewStyle())
}
func deleteItems(at offsets: IndexSet) {
withAnimation {
ingredientsStore.items.remove(atOffsets: offsets)
}
}
}
如果 searchText 为空,则效果很好,但如果列表被过滤,则不起作用。调试器显示'offsets'总是包含过滤列表中的索引(我在屏幕上看到的),例如它将是 ingredientsStore.items[1] 但 .remove 方法会将 [1] 传递给 ObservedObject 其中 [1]将对应一个完全不同的项目,因此将从数组中删除一个错误的项目:(换句话说,过滤列表包含具有绝对值的索引,据我所知。您的治疗将不胜感激。谢谢。
解决方案
ingredientsStore.items.remove(atOffsets: offsets)
这里的 offsets 是 searchResults 的索引。
所以你应该从 searchResults 中获取成分项目,然后从成分存储.items 中删除它。</p>
试试这个:
for offset in offsets{
if let index = ingredientsStore.items.firstIndex(searchResults[offset]) {
ingredientsStore.items.remove(at: index)
}
}
推荐阅读
- flutter - Flutter - 如果文本字段为空,如何防止在文本字段中调用“onChanged”?
- amazon-web-services - 摄取时 CSV 文件(在新事件下)出现奇怪的“不支持文件格式”错误
- python - Pytorch张量酸洗在运行之间不一致
- php - 等待 botman 对话结束并继续
- xamarin.forms - 格式错误的 redirect_uri,即使它匹配 AllowedRedirectUris 值
- html - 用 CSS 制作的形状不断溢出父容器
- python - 生成人工窗口调整大小 TKinter Python
- sql - SQL:删除两列与另一行中的值匹配的行
- design-patterns - 在不同的服务器中获取数据
- reason - How can I type a JS module method from Reason?