Já jsem pracoval na projektu, který se pokouší prezentovat a odmítnout názory v NavigationView pomocí státu a závazné. Důvod, proč tohle dělám, je, že je chyba v @Prostředí(.presentationMode) var presentaionMode: Vazba model. To způsobuje podivné chování. Je diskutována v tomto příspěvku zde.
Příklad uvedený níže má tři názory, které jsou postupně načteny na pohled. První dva ContentView, aby NavView1 dárek a odvolává dokonale. Nicméně, jakmile NavView2 je nabitá, tlačítko, které se používá k přepínání stavu presentNavView2 skončí přidávání další NavView2 zobrazit na zásobníku a není ji zamítl, jak se očekávalo. Jakékoli myšlenky na to, proč by to mohlo být?
ContentView
struct ContentView: View {
@State private var presentNavView1 = false
var body: some View {
NavigationView {
List {
NavigationLink(destination: NavView1(presentNavView1: self.$presentNavView1), isActive: self.$presentNavView1, label: {
Button(action: {
self.presentNavView1.toggle()
}, label: {
Text("To NavView1")
}) // Button
}) // NavigationLink
} // List
.navigationTitle("Home")
} // NavigationView
} // View
}
NavView1
struct NavView1: View {
@State private var presentNavView2 = false
@Binding var presentNavView1: Bool
var body: some View {
List {
NavigationLink(destination: NavView2(presentNavView2: self.$presentNavView2), isActive: self.$presentNavView2, label: {
Button(action: {
self.presentNavView2.toggle()
}, label: {
Text("To NavView2")
}) // Button
}) // NavigationLink
Button(action: {
self.presentNavView1.toggle()
}, label: {
Text("Back")
})
} // List
.navigationTitle("NavView1")
} // View
}
NavView2
struct NavView2: View {
@Binding var presentNavView2: Bool
var body: some View {
VStack {
Text("NavView2")
Button(action: {
self.presentNavView2.toggle()
}, label: {
Text("Back")
}) // Button
} // VStack
.navigationTitle("NavView2")
}
}