SwiftUI JSON n'imprimera pas le titre dans ScrollView HStack (mais le fera dans la liste)
J'obtiens des erreurs dans mon fichier ContentView.swift, et comme j'essaie d'apprendre, je ne comprends pas ce que les erreurs disent.
Je comprends qu'il ne peut pas attribuer la valeur de type Programme au type Post, mais comment suis-je censé obtenir le titre?
Comment puis-je l'imprimer dans HStack?
import SwiftUI
import RemoteImage
struct ContentView: View {
@State var posts: [Program] = []
var body: some View {
List(posts){ post in
Text("hello")
/*RemoteImage(type: .url(URL(string:post.url)!), errorView: { error in
Text(error.localizedDescription)
}, imageView: { image in
image
.resizable()
.aspectRatio(contentMode: .fit)
}, loadingView: {
Text("Loading ...")
})*/
// UrlImageView(post.url)
} .onAppear {
Api().getPosts { (posts) in
self.posts = posts
}
}
}
}
import SwiftUI
// Add this top level struct to
// decode properly
struct Post: Codable {
var programs: [Program]
}
struct Program: Codable, Identifiable {
let id = UUID()
var title : String
var icon : String
}
class Api {
// Update this to return an array of Program
func getPosts(completion: @escaping ([Program]) -> ()) {
guard let url = URL(string: "https://api.drn1.com.au/api-access/programs/DRN1") else { return }
URLSession.shared.dataTask(with: url) { (data, _, _) in
// Based on the updated structs, you would no
// longer be decoding an array
let post = try! JSONDecoder().decode(Post.self, from: data!)
DispatchQueue.main.async{
// The array is stored under programs now
completion(post.programs)
}
}
.resume()
}
}
Cela fonctionne également mais il n'est pas possible de faire défiler.
ForEach(posts){ post in
HStack {Text(post.title)}
}.onAppear{
Api().getPosts { (posts) in
self.posts = posts
}
}
pour être clair, le résultat final que j'essaie d'obtenir est le suivant.
ScrollView(.horizontal) {
HStack(spacing: 20) {
ForEach(0..<10) {
Text("Item \($0)")
.foregroundColor(.white)
.font(.largeTitle)
.frame(width: 200, height: 200)
.background(Color.red)
}
}
}
Réponses
Veuillez nettoyer et construire le projet. Le code semble fonctionner correctement. J'ai créé un nouveau projet et j'ai simplement copié et collé le code ci-dessus que vous avez écrit et il fonctionne correctement.
MODIFIÉ - Pour afficher la liste horizontalement, veuillez utiliser le code ci-dessous:
var body: some View {
NavigationView {
if posts.isEmpty {
Text("Loading")
} else {
ScrollView(.horizontal, showsIndicators: false) {
HStack(alignment: .center, spacing: 10) {
ForEach(posts) { post in
return Text(post.title)
}
}
}.frame(height: 200)
}
}.onAppear {
Api().getPosts { (posts) in
self.posts = posts
}
}.navigationBarTitle(Text("Home"))
}