在SwiftUI中使用NavigationLink导航时如何隐藏TabBar?

时间:2019-08-01 08:30:53

标签: ios swiftui

我有一个带有2个标签的TabView,每个标签都包含一个NavigationView。导航到另一个视图时,我需要隐藏TabBar。一种解决方案是将TabView放在一个NavigationView内,但是我必须为每个NavigationView设置不同的属性。

TabView(selection: $selectedTab, content: {
            NavigationView {
                VStack {
                    NavigationLink(destination: Text("SecondView Tab1")) {
                        Text("Click")
                    }
                }
            }.tabItem {
                Text("ONE")
            }.tag(0)

            NavigationView {
                VStack {
                    NavigationLink(destination: Text("SecondView Tab2")) {
                        Text("Click")
                    }
                }
            }.tabItem {
                Text("TWO")
            }.tag(1)

        })

P.S。我正在使用Xcode 11 Beta 5

4 个答案:

答案 0 :(得分:1)

这应该可行,因为NavigationView托管了可表示的UINavigationController:

spath

答案 1 :(得分:0)

据我所知,如果导航视图作为子项列出,则无法隐藏该选项卡,您的选项卡包含导航视图。

答案 2 :(得分:0)

稍晚一些,但可以使用,在选项卡式视图中使用导航链接时,将NavigationView放在TabView和选项卡按钮将被隐藏之前。

NavigationView{
    TabView{
        ...
    }
}

答案 3 :(得分:0)

我对此有同样的问题; 为了解决这个问题,我做了以下动作:

  1. 使用NavigationView Contain a TabViewHidden the NavigationBar
  2. 像这样制作自定义NavigaitonView
  3. 在下一个视图中仍隐藏的NavigationBar
// root tab
NavigationView {
    TabView {
        // some
    }
    .navigationBarTitle(xxx, displayMode: .inline)
    .navigationBarHidden(true)
}
// custom navigation view
@available(iOS 13.0.0, *)
struct MyNavigationView: View {
    var body: some View {
        HStack {
            Spacer()
            Text(some)
            Spacer()
        }
        .frame(height: 44)
    }
}
// this view 
VStack {
                MyNavigationView()
                Image(some)
                    .resizable()
                    .frame(width: 100, height: 100, alignment: .top)
                    .padding(.top, 30)
                Spacer()
                HStack {
                    ClockView()
                    Spacer()
                    NavigationLink(
                        destination: DynamicList(),
                        label: {
                            Image(some)
                        }).navigationBarHidden(true)
                }
                .padding(EdgeInsets(top: 0, leading: 15, bottom: 0, trailing: 15))
                
                Spacer()
            }
// next view
var body: some View {
            VStack {
                List {
                    MyNavigationView()
                    ForEach(date, id: \.self) { model in
                        Text(model)
                    }
                }
                .navigationBarHidden(true)
                .navigationBarTitle(some, displayMode: .inline)
            }
    }