本章我们将演示,如何通过EditButton来让列表进入可编辑模式。
Getting ready
新建一个SwiftUI项目ListRowEdit
How to do it…
我们将沿用上个例子的代码
- 复制上个项目中ContentView中的代码过来
struct ContentView: View {
@State var countries = ["USA", "Canada", "England", "Cameroon", "South Africa", "Mexico" , "Japan", "South Korea"]
var body: some View {
NavigationView {
List {
ForEach(countries, id: \.self) { country in
Text(country)
}.onDelete(perform: self.deleteItem)
}.navigationTitle("Countries")
.navigationBarTitleDisplayMode(.inline)
}
}
func deleteItem(at indexSet: IndexSet) {
self.countries.remove(atOffsets: indexSet)
}
}
- 为navigation bar添加一个editButton
.navigationBarItems(trailing: EditButton())
- 点击Edit按钮,进入编辑模式,点击“-” ,将出现delete按钮,选择delete,将删除Item
How it works…
.navigationBarItems(trailing: EditButton())在右上角增加了一个按钮。点击后,将在每个Cell前出现一个减号。点击减号,将出现delete按钮,选择delete将删除cell。