質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.35%
Swift

Swiftは、アップルのiOSおよびOS Xのためのプログラミング言語で、Objective-CやObjective-C++と共存することが意図されています

Q&A

解決済

1回答

661閲覧

PKを指定したエンドポイントでAPIの値を取得する方法

tomaa

総合スコア84

Swift

Swiftは、アップルのiOSおよびOS Xのためのプログラミング言語で、Objective-CやObjective-C++と共存することが意図されています

0グッド

0クリップ

投稿2020/10/13 16:17

前提・実現したいこと

SwiftUIを利用してアプリの開発をしています。

アプリからWebAPIを利用して値を取得するためのコードを作成しています。

リストの形では値の取得ができるのですが、エンドポイントにPKを含めた指定にするとエラーが出てしまいます。
↓このエンドポイントの指定であれば値は取得できます。

https://sample.com/api/test/

↓このように、PK値を指定すると下記のエラーが発生していまいます。

https://sample.com/api/test/1/

対応策について、ご存知の方おりましたらご教授いただけないでしょうか?

発生している問題・エラーメッセージ

Thread 1: Fatal error: 'try!' expression unexpectedly raised an error: Swift.DecodingError.typeMismatch(Swift.Array<Any>, Swift.DecodingError.Context(codingPath: [], debugDescription: "Expected to decode Array<Any> but found a dictionary instead.", underlyingError: nil))

該当のソースコード

ViewModel.swift

SWIFT

1import Foundation 2import Combine 3 4class ViewModel: ObservableObject { 5 6 @Published var infos: [Infos] = [] 7 8 9 init() { 10 load() 11 } 12 13 func load() { 14 let url = URL(string: "https://sample.com/api/test/")! 15 // let url = URL(string: "https://sample.com/api/test/1/")! こちらはエラー 16 URLSession.shared.dataTask(with: url) { data, response, error in 17 DispatchQueue.main.async { 18 self.infos = try! JSONDecoder().decode([Infos].self, from: data!) 19 } 20 }.resume() 21 } 22 } 23 24 struct Infos: Codable, Identifiable { 25 var id: Int 26 var name: String 27}

ContentView.swift

SWIFT

1import SwiftUI 2 3struct ContentView: View { 4 5 @ObservedObject var appState = ViewModel() 6 7 var body: some View { 8 List(appState.infos) { (info) in 9 UserRow(info: info) 10 } 11 } 12} 13 14struct UserRow: View { 15 var info:Infos 16 17 var body: some View { 18 Text(info.name) 19 20 } 21} 22 23struct ContentView_Previews: PreviewProvider { 24 static var previews: some View { 25 ContentView() 26 } 27}

補足情報(FW/ツールのバージョンなど)

XCode: Version 12.0.1

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

自己解決

下記のコードで実装できました。

SWIFT

1import Foundation 2import Combine 3 4class ViewModel: ObservableObject { 5 6 @Published var infos: Infos? 7 8 9 init() { 10 load() 11 } 12 13 func load() { 14 let url = URL(string: "https://sample.com/api/test/1/")! 15 URLSession.shared.dataTask(with: url) { data, response, error in 16 DispatchQueue.main.async { 17 self.infos = try! JSONDecoder().decode(Infos.self, from: data!) 18 } 19 }.resume() 20 } 21 } 22 23 struct Infos: Codable{ 24 var name: String 25}

SWIFT

1import SwiftUI 2 3struct ContentView: View { 4 5 @ObservedObject var appState = ViewModel() 6 7 var body: some View { 8 Text(appState.infos?.name ?? "") 9 10 } 11} 12 13 14 15struct ContentView_Previews: PreviewProvider { 16 static var previews: some View { 17 ContentView() 18 } 19}

投稿2020/10/14 07:07

tomaa

総合スコア84

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.35%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問