【问题标题】:How to prevent NavigationView from affecting subviews如何防止 NavigationView 影响子视图
【发布时间】:2020-08-12 04:31:54
【问题描述】:

我想使用 NavigationView 有几个原因,但是当我将视图层次结构包装在 NavigationView 中时,事情变得一团糟。屏幕 1 显示了我想要的效果,但 NavigationView 尚未添加。屏幕一的代码是:

struct ContentView: View {
    var body: some View {

        VStack(spacing:0) {
            Text("Text Above List")
                .frame(width: 375, height: 44)
                    .background(Color.gray)
            List() {
                Text("Row 1")
                Text("Row 2")
                Text("Row 3")
                Text("Row 4")
                Text("Row 5")
              }
         }
    }
 }

通过包装在 NavigationView 中,结果是屏幕 2。屏幕 2 的代码是:

    struct ContentView: View {
    var body: some View {
        NavigationView {
            VStack(spacing:0) {
                Text("Text Above List")
                    .frame(width: 375, height: 44)
                    .background(Color.gray)
                List() {
                    Text("Row 1")
                    Text("Row 2")
                    Text("Row 3")
                    Text("Row 4")
                    Text("Row 5")
                }
            }
            .navigationBarHidden(true)
        }
    }
}

然后通过添加“.listStyle(GroupedListStyle())”,结果是屏幕 3 - 很接近但没有雪茄。我无法摆脱列表上方但在其上方文本视图下方的空间。该空间显然是标题视图,但我不能让它消失。屏幕 3 的代码是:

struct ContentView: View {
    var body: some View {
        NavigationView {
            VStack(spacing:0) {
                Text("Text Above List")
                    .frame(width: 375, height: 44)
                    .background(Color.gray)
                List() {
                    Text("Row 1")
                    Text("Row 2")
                    Text("Row 3")
                    Text("Row 4")
                    Text("Row 5")
                }
                .listStyle(GroupedListStyle())
            }
            .navigationBarHidden(true)
        }
    }
}

对此的任何帮助将不胜感激。我已经把头发拉出来太久了。谢谢enter link description here

点击上面的“在此处输入链接描述”链接,查看引用的屏幕。

【问题讨论】:

    标签: list swiftui navigationview


    【解决方案1】:

    我假设你想要简单的列表样式

    var body: some View {
        NavigationView {
            VStack(spacing:0) {
                Text("Text Above List")
                    .frame(maxWidth: .infinity, minHeight: 44)
                    .background(Color.gray)
                List() {
                    Text("Row 1")
                    Text("Row 2")
                    Text("Row 3")
                    Text("Row 4")
                    Text("Row 5")
                }.listStyle(PlainListStyle())     // << here !!
            }
            .navigationBarHidden(true)
        }
    }
    

    【讨论】:

    • 天哪,这很容易......谢谢。我做了一个假设,因为只有两种列表样式可用,并且设置为 groupstyle 明显改变了外观,而不是指定默认为 plainstyle 的样式。我经常被提醒要做出假设……这又让我难过。
    • 不客气。在 SwiftUI 默认样式中,如果该 UI 元素有样式,则依赖于平台,因此根本不需要假设 - 如果您希望某些东西看起来持久,则应该明确设置样式,因为如果没有,它可能在 iPad 上看起来不同,甚至如果在 iPhone 上测试期间它看起来对您来说还可以。以防万一。顺便说一句...What should I do when someone answers my question?
    猜你喜欢
    • 1970-01-01
    • 2015-09-19
    • 1970-01-01
    • 2023-03-08
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多