2

我制作了一个自定义标签栏,因为系统不能在纯 swiftUI 中自定义。

自定义选项卡视图如下所示:

struct MainTabView: View {  
    var body: some View {
        VStack(spacing: 0) {
            switch router.currentTab {
            case .tab1:
                Tab1View()
            case .tab2:
                Tab2View()
            ...
            }
            Spacer()
            HStack(spacing: 0) {
                TabBarIconView(viewRouter: viewRouter, ...)
                TabBarIconView(viewRouter: viewRouter, ...)
                TabBarIconView(viewRouter: viewRouter, ...)
                TabBarIconView(viewRouter: viewRouter, ...)
                TabBarIconView(viewRouter: viewRouter, ...)
            }
          //.ignoresSafeArea(.keyboard) // second try
        }
    }
    //.ignoresSafeArea(.keyboard) // first try
}

当我在其中一个 TabXViews 中使用 textfied 时,底部的 HStack 保持在键盘上方。

我发现的一个解决方案是禁用标签栏的键盘避免功能。我通过取消注释上面的行来做到这一点.ignoresSafeArea(.keyboard)(第一次尝试)

但是,当然,这适用于全局,对于每个子视图 => 如果我声明一个滚动视图,则在打开键盘时将无法访问底部。

.ignoresSafeArea(.keyboard)尝试在上面的 HStack 下设置(第二次尝试),但这没有做任何事情(HStack 停留在键盘上方)

是否有解决方案可以在子视图中再次选择避免键盘?

4

0 回答 0