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

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

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

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

解決済

SwiftUIの初期画面(ContentView)でButtonのactionなしに関数を実行する書き方について

DeepRoastBeans
DeepRoastBeans

総合スコア77

Swift

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

1回答

1評価

0クリップ

418閲覧

投稿2022/01/28 04:38

「iPhone アプリ開発集中講座」という本を参考に、pythonなどで処理したjsonを取得して、そのデータを一覧表示するアプリを作ろうとしています。
ContentVidwのButton(action: {})で関数を呼び出して、Jsonから取得したデータをList表示するところまでは出来たのですが、Buttonを押さずに関数を実行するには、どのように書いたら良いのでしょうか?

下記の await bousaiDataList.getPopulation() をbuttonを押さずに、アプリを開いたタイミングで実行させたいです。

ContentView.swift

swift

import SwiftUI struct ContentView: View { @StateObject var bousaiDataList = BousaiData() var body: some View { VStack { Text("Hello, world!") .padding() Button(action: { Task { await bousaiDataList.getPopulation() } }){ Text("表示") } List(bousaiDataList.bousaiList) { bousai in HStack() { Text(bousai.area) Text("\(bousai.population)") Text(bousai.capital) } } } } }

BousaiData.swift

swift

import SwiftUI import UIKit struct BousaiItem: Identifiable { let id = UUID() let area: String let population: UInt let capital: String } class BousaiData: ObservableObject { struct ResultJson: Codable { struct Item: Codable { let area: String? let population: UInt? let capital: String? } let item: [Item]? } @Published var bousaiList: [BousaiItem] = [] func getPopulation() async { print("hello!") guard let req_url = URL(string: "https://hoge.com/population.json") else { return } print(req_url) do { let (data, _) = try await URLSession.shared.data(from: req_url) let decoder = JSONDecoder() let json = try decoder.decode(ResultJson.self, from: data) guard let items = json.item else { return } DispatchQueue.main.async { self.bousaiList.removeAll() } for item in items { if let area = item.area, let population = item.population, let capital = item.capital { let bousai = BousaiItem(area: area, population: population, capital: capital) DispatchQueue.main.async { self.bousaiList.append(bousai) } } } print(self.bousaiList) } catch { print("エラーが出ました") } } }

イメージ説明

-> 今の実装だと、ボタンを押さないと表示されない

良い質問の評価を上げる

以下のような質問は評価を上げましょう

  • 質問内容が明確
  • 自分も答えを知りたい
  • 質問者以外のユーザにも役立つ

評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

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

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

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

teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

  • プログラミングに関係のない質問
  • やってほしいことだけを記載した丸投げの質問
  • 問題・課題が含まれていない質問
  • 意図的に内容が抹消された質問
  • 過去に投稿した質問と同じ内容の質問
  • 広告と受け取られるような投稿

評価を下げると、トップページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

まだ回答がついていません

会員登録して回答してみよう

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

ただいまの回答率
87.20%

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

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

質問する

関連した質問

同じタグがついた質問を見る

Swift

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