在推送 View 中修改列表绑定(bind)属性时,SwiftUI 导航会弹出

标签 swiftui swiftui-navigationlink swiftui-navigationview

当我从向下推送 View 2+ 层中的数组更新绑定(bind)属性时,导航会在更改属性后立即弹出。
Xcode 13.3 测试版,iOS 15。
我创建了一个简单的演示,代码如下。


购物 list
列表编辑
列表部分 编辑


ShoppingListsView
ShoppingListEditView
ShoppingListEditsectionView


更新列表标题(一个 View 深)很好,导航堆栈保持不变,如果我返回,更改会发布。但是在调整部分标题(两个深)时,只要我对该属性进行了一次更改,导航就会弹出。
我有一种感觉,我在这里缺少基本的基础知识,而且我觉得它一定与列表有关 id ?但我正在努力弄清楚或解决它。
GIF
Example
代码:
型号:

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/

相关文章:

ios - UIPageViewController 滑动忽略 SwiftUI 的 navigationBarHidden(true)

ios - SwiftUI NavigationLink 自动弹出,这是意外的

SwiftUI:单击按钮时如何呈现 View ?

swiftui - 在 Swift UI 中导致灰屏的导航链接

ios - 如何删除 SwiftUI NavigationView 中的默认导航栏空间

单个 View 的 macOS SwiftUI 导航

ios - SwiftUI应用程序卡住几秒钟,然后进入前台

json - 如何在 SwiftUI 中显示来自 API 的 JSON 数据?

ios - SwiftUI Textfield Binding 在 iOS 15 中触发 2 次

ios - SwiftUI NavigationLink 在 Xcode 11.4 模拟器中仍然损坏?