【问题标题】:I am not able to overwrite NavigationItemTitle into TabView in SwiftUI我无法在 SwiftUI 中将 NavigationItemTitle 覆盖到 TabView
【发布时间】:2021-01-02 22:57:04
【问题描述】:

我是 SwiftUI 的新手。我有一个 ContentView,因为我添加了 NavigationView 并从该 NavigationView 重定向到另一个具有 TabView 的视图。

//ContentView.swift

struct ContentView: View {

  @State private var isValidLogin : Bool = false    

  var body: some View {
    NavigationView{
         VStack
         {
           NavigationLink(destination: HomePage(), isActive:$isValidLogin) {
                Text("LOGIN")
                    .font(.headline)
                    .foregroundColor(.white)
                    .padding()
                    .onTapGesture {
                         self.isValidLogin = true
                    }
          }
        }.padding()
      }
   }
} 

这里是 HomePage.swift 的代码

import SwiftUI

struct HomePage: View {

private enum Tab: Hashable {
    case home
    case map
}
@State private var selectedTabbar : Tab = .home

var body: some View {
    TabView(selection: $selectedTabbar)
    {
        HomeView()
            .tag(0)
            .tabItem{
                Text("Home")
                Image(systemName: "house.fill")
            }
        
        MapView()
            .tag(1)
            .tabItem {
                Text("Map")
                Image(systemName: "map")
            }
    }.navigationBarTitle("Settings")
 }
}

struct HomePage_Previews: PreviewProvider {
    static var previews: some View {
        HomePage()
    }
}

这里是 MapView.swift 的代码

import SwiftUI

struct MapView: View {

var body: some View {
    Text("You are in Map Page")
        .navigationBarTitle(Text("Map"), displayMode: .inline)
 }
} 
struct MapView_Previews: PreviewProvider {
    static var previews: some View {
        MapView()
    }
}

我的错误是:当我将全局标题设置为 TabView 属性时,.navigationBarTitle("Settings") 总是反映。但是我想要这样,如果我将 NavigationTitle 设置为子视图,那么它将显示在该子视图中。当我们点击地图项时,我需要这样的导航标题应该地图。当我们将导航标题应用于子项时,我找不到错误为什么它不起作用。

任何帮助都应该感激。提前致谢。

【问题讨论】:

  • 这是因为在您的示例中,只有TabView 被视为NavigationVIew 的直接子级,并且仅应用了设置为TabView 的导航标题。这篇文章可能对您有所帮助:stackoverflow.com/q/61970939/8697793
  • 感谢@pawello2222 的帮助。我从这个链接中找到了一个解决方案。它得到了解决方案。非常感谢。

标签: swiftui navigationview tabview tabitem navigationitem


【解决方案1】:

我找到了解决办法。

这里我改了HomePage:

struct HomePage: View {
    @State private var selectedTabbar = 0
    
    var body: some View {
        TabView(selection: $selectedTabbar)
        {
            HomeView()
                .tag(0)
                .tabItem{
                    Text("Home")
                    Image(systemName: "house.fill")
                }
            MapView()
                .tag(1)
                .tabItem {
                    Text("Map")
                    Image(systemName: "map")
                }  Image(systemName: "gear")
                }
        }.navigationBarTitle(Text(navigationBarTitle))
        .navigationBarBackButtonHidden(true)
        .accentColor(.red)
    }
}

我为HomePage 添加了一个扩展名。它正在设置子视图的导航标题:

private extension HomePage {
    var navigationBarTitle: String {
        selectedTabbar ==  0 ? "Home" : "Map"
    }
}

使用此扩展,我们可以将动态导航标题设置为TabView

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 2021-03-08
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2021-10-17
    • 2018-10-02
    • 1970-01-01
    • 2020-01-06
    相关资源
    最近更新 更多