繁体   English   中英

单击 SwiftUI 中的 NavigationLink 后隐藏 TabView

[英]hide TabView after clicking on a NavigationLink in SwiftUI

当我有一个TabView{}并且第一个 Tab 有一个NavigationView时,当我点击一个Row时,我希望那个TabView{}消失。 我怎么做?

同样的问题: 如何在 SwiftUI 中使用 NavigationLink 导航时隐藏 TabBar?

但不幸的是没有解决方案。

目前没有办法做到这一点。 例如, NavigationView响应其后代的.navigationBarHidden(_:)方法,但TabView没有等效项。

如果这是您想看到的,请让 Apple 知道

没有办法隐藏 TabView,所以我不得不在 ZStack 中添加 TabView,如下所示:

var body: some View {
    ZStack {
        TabView {
            TabBar1().environmentObject(self.userData)
                .tabItem {
                    Image(systemName: "1.square.fill")
                    Text("First")
            }
            TabBar2()
                .tabItem {
                    Image(systemName: "2.square.fill")
                    Text("Second")
            }
        }

        if self.userData.showFullScreen {
            FullScreen().environmentObject(self.userData)

        }
    }
}

用户数据:

  final class UserData: ObservableObject {
    @Published var showFullScreen = false}

标签栏1:

struct TabBar1: View {
    @EnvironmentObject var userData: UserData

    var body: some View {
        Text("TabBar 1")
            .edgesIgnoringSafeArea(.all)
            .frame(width: UIScreen.main.bounds.width, height: UIScreen.main.bounds.height)
            .background(Color.green)
            .onTapGesture {
                self.userData.showFullScreen.toggle()
        }
    }
}

全屏:

struct FullScreen: View {
    @EnvironmentObject var userData: UserData

    var body: some View {
        Text("FullScreen")
            .edgesIgnoringSafeArea(.all)
            .frame(width: UIScreen.main.bounds.width, height: UIScreen.main.bounds.height)
            .background(Color.red)
            .onTapGesture {
                self.userData.showFullScreen.toggle()
        }
    }
}

检查Github上的完整代码

还有其他一些方法,但这取决于视图的结构

为了解决这个限制,我提出了这种方法:

  • 创建了一个枚举来识别选项卡
enum Tabs: Int {
    case tab1
    case tab2
    
    var title: String {
        switch self {
        case .tab1: return "Tab 1 Title"
        case .tab2: return "Tab 2 Title"
        }
    }

    var imageName: String {
        switch self {
        case .tab1: return "star" // Example using SF Symbol
        case .tab2: return "ellipsis.circle"
        }
    }
}
  • 在视图内部,例如ContentView.swift ,添加了如下属性:
@State private var selectedTab = Tabs.tab1
  • 体内:
NavigationView {
    TabView(selection: $selectedTab) {
        ViewExample1()
            .tabItem {
                Image(systemName: Tabs.tab1.imageName)
                Text(Tabs.tab1.title)
        }.tag(Tabs.tab1)
        
        ViewExample2()
            .tabItem {
                Image(systemName: Tabs.tab2.imageName)
                Text(Tabs.tab2.title)
        }.tag(Tabs.tab2)
    }
    .navigationBarTitle(selectedTab.title)
}

就这样。 我希望这可能会有所帮助。

注意:请注意,此解决方法将 TabView 隐藏在任何和所有子视图中,如果您只想隐藏在特定视图中,这不会为您提供所需的结果。

希望 Apple 很快实现一个(官方和适当的)选项来隐藏 TabView。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM