Dynamiczna nawigacja link SwiftUI Xcode

0

Pytanie

W moim domowym oglądania mam 2 karty. Tworzę dwie nowe strony (AboutA i AboutB), które będą związane z każdą z tych kartek. Ale jeśli nacisnę na tę kartę, dostanę tylko podgląd pierwszej strony, bo nie wiem, jak skonfigurować dynamiczną nawigację dla każdej z nich. To w moim domowym oglądania:

ForEach(items) { item in
    NavigationLink(destination: AboutA()) {
    CardView(item: item)
}

Karty tworzę "dane":

struct Item: Identifiable {
    var id = UUID()
    var title: String
    var text: String
    var image: String
}

Teraz potrzebna mi pomoc, co zmienić w domowym oglądania i co zmienić na stronie "dane".

Dziękuję.

swift swiftui swiftui-navigationlink
2021-11-22 16:19:26
2
0

Masz dwie karty, i trzeba je pokazać dane w innym widoku, o której dzwonisz. Ponieważ ich natura jest podobna, ja również uważam, że strona jest bardzo podobna lub nawet równa. Możliwe, przedstawienie " O "jest taka sama dla obu widoków, dlatego najlepiej utworzyć dynamiczne przedstawienie "O". :

struct Item: Identifiable {
    var id = UUID()
    var title: String
    var text: String
    var image: String
}

struct ContentView: View {
    @State
    var items : [Item] = [Item(title: "A", text: "test text", image: "test image"), Item(title: "B", text: "test text", image: "test image")]
    
    var body: some View {
        NavigationView {
            ForEach(items) { item in
                NavigationLink(destination: AboutView(item : item)) {
                    Text(item.text)
                }
            }
        }
    }
}

struct AboutView : View {
    var item : Item
    var body : some View {
        Text(item.title)
    }
}

W ten sposób, widok AboutView ma taką samą strukturę dla obu kart, ale będzie ono wypełnione prawidłowymi danymi. Można oczywiście dodać jakiś element sterowania, aby zrozumieć, co to za mapa i edytować coś w widoku.

2021-11-23 08:41:10
0

Dobrze, postanowiłem swój problem z kartą linków na nowe strony, ale u mnie pojawił się nowy problem :)

struct HomeView: View {
@State var show = false
var body: some View {
    NavigationView {
        ScrollView {
            ScrollView(.horizontal, showsIndicators: false) {
                HStack{
                    ForEach(items) { item in
                        NavigationLink(destination: AboutH()) {
                            CardView(item: items[0])}
                            NavigationLink(destination: Parkovi()) {
                                CardView(item: items[1])}
                                NavigationLink(destination: Rijeke()) {
                                    CardView(item: items[2])
                            }
                        }
                        
                    }
                }

Teraz mam 3 karty, które są linkami do strony, ale mam czas w drzewie w rzędzie identycznych kartek :(

Jakaś pomoc? Dziękuję.

2021-11-25 00:10:01

W innych językach

Ta strona jest w innych językach

Русский
..................................................................................................................
Italiano
..................................................................................................................
Română
..................................................................................................................
한국어
..................................................................................................................
हिन्दी
..................................................................................................................
Français
..................................................................................................................
Türk
..................................................................................................................
Česk
..................................................................................................................
Português
..................................................................................................................
ไทย
..................................................................................................................
中文
..................................................................................................................
Español
..................................................................................................................
Slovenský
..................................................................................................................