当我从向下推送 View 2+ 层中的数组更新绑定(bind)属性时,导航会在更改属性后立即弹出。
Xcode 13.3 测试版,iOS 15。
我创建了一个简单的演示,代码如下。
购物 list
列表编辑
列表部分 编辑
更新列表标题(一个 View 深)很好,导航堆栈保持不变,如果我返回,更改会发布。但是在调整部分标题(两个深)时,只要我对该属性进行了一次更改,导航就会弹出。
我有一种感觉,我在这里缺少基本的基础知识,而且我觉得它一定与列表有关 id
?但我正在努力弄清楚或解决它。
GIF
代码:
型号:
struct ShoppingList {
let id: String = UUID().uuidString
var title: String
var sections: [ShoppingListSection]
}
struct ShoppingListSection {
let id: String = UUID().uuidString
var title: String
}
查看型号:final class ShoppingListsViewModel: ObservableObject {
@Published var shoppingLists: [ShoppingList] = [
.init(
title: "Shopping List 01",
sections: [
.init(title: "Fresh food")
]
)
]
}
内容查看:struct ContentView: View {
var body: some View {
NavigationView {
ShoppingListsView()
}
}
}
购物 list 查看 struct ShoppingListsView: View {
@StateObject private var viewModel = ShoppingListsViewModel()
var body: some View {
List($viewModel.shoppingLists, id: \.id) { $shoppingList in
NavigationLink(destination: ShoppingListEditView(shoppingList: $shoppingList)) {
Text(shoppingList.title)
}
}
.navigationBarTitle("Shopping Lists")
}
}
购物 list 编辑 View struct ShoppingListEditView: View {
@Binding var shoppingList: ShoppingList
var body: some View {
Form {
Section(header: Text("Title")) {
TextField("Title", text: $shoppingList.title)
}
Section(header: Text("Sections")) {
List($shoppingList.sections, id: \.id) { $section in
NavigationLink(destination: ShoppingListSectionEditView(section: $section)) {
Text(section.title)
}
}
}
}
.navigationBarTitle("Edit list")
}
}
ShoppingListSectionEditView struct ShoppingListSectionEditView: View {
@Binding var section: ShoppingListSection
var body: some View {
Form {
Section(header: Text("Title")) {
TextField("title", text: $section.title)
}
}
.navigationBarTitle("Edit section")
}
}
最佳答案
试试这个,对我有用:
struct ContentView: View {
var body: some View {
NavigationView {
ShoppingListsView()
}.navigationViewStyle(.stack) // <--- here
}
}
关于在推送 View 中修改列表绑定(bind)属性时,SwiftUI 导航会弹出,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/69143014/