Dynamické NavigationLink SwiftUI Xcode

0

Otázka

V mojom HomeView som 2 karty. Som urobiť dve nové stránky (AboutA a AboutB) byť prepojené na každom z tejto karty. Ale ak kliknem na tejto karte mám len ukážka prvej stránke, pretože neviem, ako nastaviť dynamics navigácia pre každého. To je v mojom HomeView:

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

Pre Kartu som vytvoriť "data":

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

Teraz potrebujem pomoc, čo zmeniť v HomeView, a čo zmeniť v "data" stránky.

ďakujem.

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

Máte dve karty, a budete musieť preukázať svoje osobné údaje v inom okne, aby ste hovor O. Ako ich povaha je podobné, myslím, že aj O stránke je veľmi podobné alebo dokonca rovnaké. Možno O Zobrazenie je rovnaké pre obidva hľadiska, tak lepšie vec urobiť, je vytvoriť dynamickú O Zobrazenie :

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)
    }
}

Takže AboutView má rovnakú štruktúru pre kartu, ale to bude naplnená správnych údajov. Určite môžete pridať niektoré kontroly pochopiť, čarodejnice karty je to, a upraviť niečo v okne.

2021-11-23 08:41:10
0

Ok, som vyriešil môj problém s odkaz karty na nové stránky, ale ja si nový problém :)

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 mám 3 karty, ktoré sú prepojenia na stránky, ale ja som strom čas v riadku rovnaké karty :(

Akákoľvek pomoc? Ďakujem.

2021-11-25 00:10:01

V iných jazykoch

Táto stránka je v iných jazykoch

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