How to hide `tabbar` in iOS 18?

I wrapped my view in a NavigationStack and used .toolbarVisibility(.hidden, for: .tabBar) to navigate while hiding the tab bar. However, this causes an issue: the transition animation becomes stiff and unnatural. I haven’t found a good solution yet.
I’m trying to research how Apple’s official apps handle this. It seems that many of them simply present a new view when they need to hide the tab bar.
The tab bar is generally always visible. When an app needs to hide it, the common pattern is to present a modal view, rather than pushing a view inside the existing navigation stack.
The completed code is here:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
import SwiftUI
struct ContentView: View {
var body: some View {
TabView {
HomeTab()
.tabItem {
Label("Home", systemImage: "house.fill")
}
Text("Settings Tab")
.tabItem {
Label("Settings", systemImage: "gear")
}
}
}
}
struct HomeTab: View {
var body: some View {
NavigationStack {
MainView()
}
}
}
struct MainView: View {
var body: some View {
List {
NavigationLink("Go to Detail Page 1") {
DetailView(title: "Detail 1")
.toolbarVisibility(.hidden, for: .tabBar)
}
NavigationLink("Go to Detail Page 2") {
DetailView(title: "Detail 2")
}
}
.navigationTitle("Main View")
}
}
struct DetailView: View {
let title: String
var body: some View {
Text("This is the \(title)")
.navigationTitle(title)
.navigationBarTitleDisplayMode(.inline)
}
}
#Preview {
ContentView()
}