Bob*_*Bob 3 list swiftui navigationlink
我正在寻找有关 SwiftUI 的一些指导。
我有一个视图显示一个简单的列表,每行显示一个“名称”字符串。您可以通过单击尾随导航栏按钮将项目添加到数组/列表。这工作正常。我现在想使用 NavigationLink 来呈现一个新的“DetailView”,我可以在其中编辑行的“name”字符串。我正在努力解决如何在 detailview 中使用绑定来更新名称。
我在网上找到了很多关于如何在新视图中呈现数据的教程,但没有关于如何编辑数据的教程。提前致谢。
内容视图:
struct ListItem: Identifiable {
let id = UUID()
let name: String
}
class MyListClass: ObservableObject {
@Published var items = [ListItem]()
}
struct ContentView: View {
@ObservedObject var myList = MyListClass()
var body: some View {
NavigationView {
List {
ForEach(myList.items) { item in
NavigationLink(destination: DetailView(item: item)) {
Text(item.name)
}
}
}
.navigationBarItems(trailing:
Button(action: {
let item = ListItem(name: "Test")
self.myList.items.append(item)
}) {
Image(systemName: "plus")
}
)
}
}
}
Run Code Online (Sandbox Code Playgroud)
详细视图
struct DetailView: View {
var item: ListItem
var body: some View {
TextField("", text: item.name)
}
}
Run Code Online (Sandbox Code Playgroud)
您在 DetailsView 中传递的主要思想不是 item,它被复制,因为它是一个值,而是绑定到您的视图模型中的相应 item。
这是一个演示,其中修改了您的代码快照以满足请求的行为:
struct ListItem: Identifiable, Equatable {
var id = UUID()
var name: String
}
class MyListClass: ObservableObject {
@Published var items = [ListItem]()
}
struct ContentView: View {
@ObservedObject var myList = MyListClass()
var body: some View {
NavigationView {
List {
ForEach(myList.items) { item in
// Pass binding to item into DetailsView
NavigationLink(destination: DetailView(item: self.$myList.items[self.myList.items.firstIndex(of: item)!])) {
Text(item.name)
}
}
}
.navigationBarItems(trailing:
Button(action: {
let item = ListItem(name: "Test")
self.myList.items.append(item)
}) {
Image(systemName: "plus")
}
)
}
}
}
struct DetailView: View {
@Binding var item: ListItem
var body: some View {
TextField("", text: self.$item.name)
}
}
Run Code Online (Sandbox Code Playgroud)
归档时间: |
|
查看次数: |
1343 次 |
最近记录: |