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

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

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

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

Q&A

解決済

1回答

454閲覧

SwiftUIで@Bindingで渡された値を、同クラス内の@StateObjectのメソッド内で更新したい

IKEH

総合スコア6

Swift

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

0グッド

0クリップ

投稿2022/09/22 05:31

編集2022/09/22 07:06

前提

ContentViewからLoginViewに渡された@Binding var isPresentingLoginView: BoolをviewModelから更新したいのですが、viewModelの初期化時に渡せないためどうすれば良いのかが分かっておりません。

実現したいこと

  • ContentViewのisPresentingLoginViewの値を、LoginViewのviewModel内で更新すること。

該当のソースコード

swift

1struct ContentView: View { 2 3 @State private var isPresentingLoginView = true 4 5 var body: some View { 6 if isPresentingLoginView { 7 LoginView(isPresentingLoginView: $isPresentingLoginView) 8 } else { 9 Text("next Login View...") 10 } 11 } 12}

swift

1struct LoginView: View { 2 3 @Binding var isPresentingLoginView: Bool // TODO: viewModelに渡して、viewModel.loginButtonPressed()の中で値を更新したい。 4 @StateObject private var viewModel = LoginViewModel() 5 6 var body: some View { 7 HStack { 8 Spacer() 9 VStack { 10 Spacer() 11 VStack { 12 TextField("ID", text: $viewModel.id) 13 .textFieldStyle(.roundedBorder) 14 SecureField("Password", text: $viewModel.password) 15 .textFieldStyle(.roundedBorder) 16 } 17 .frame(width: 200) 18 Spacer() 19 Button { 20 // ログインのAPIをたたく 21 Task { @MainActor in 22 await viewModel.loginButtonPressed() 23 } 24 } label: { 25 Text("Log in") 26 } 27 .disabled(!viewModel.isLoginButtonEnabled) 28 } 29 Spacer() 30 } 31 .alert(viewModel.errorInfo.title, isPresented: $viewModel.errorInfo.isPresentingError) { 32 Button("閉じる", action: {}) 33 } message: { 34 Text(viewModel.errorInfo.message) 35 } 36 } 37}

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

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

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

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

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

guest

回答1

0

ベストアンサー

Closuresを使って次のような感じはいかがでしょうか。

swift

1// LoginView 2Task { @MainActor in 3 await viewModel.loginButtonPressed { 4 isPresentingLoginView.toggle() 5 } 6} 7 8// LoginViewModel 9func loginButtonPressed(closure: () -> Void) async { 10 // ...処理... 11 try! await Task.sleep(nanoseconds: 3_000_000_000) 12 closure() 13}

Closures
https://docs.swift.org/swift-book/LanguageGuide/Closures.html

投稿2022/09/22 14:57

退会済みユーザー

退会済みユーザー

総合スコア0

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問