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

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

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

Flutterは、iOSとAndroidのアプリを同じコードで開発するためのフレームワークです。オープンソースで開発言語はDart。双方のプラットフォームにおける高度な実行パフォーマンスと開発効率を提供することを目的としています。

Dart

Dartは、Googleによって開発されたJavaScriptの代替となることを目的に作られた、ウェブ向けのプログラミング言語である。

Q&A

解決済

1回答

2939閲覧

Flutter ダイアログで入力した文字列を呼び出し元の画面に渡したい

sakesake

総合スコア3

Flutter

Flutterは、iOSとAndroidのアプリを同じコードで開発するためのフレームワークです。オープンソースで開発言語はDart。双方のプラットフォームにおける高度な実行パフォーマンスと開発効率を提供することを目的としています。

Dart

Dartは、Googleによって開発されたJavaScriptの代替となることを目的に作られた、ウェブ向けのプログラミング言語である。

0グッド

0クリップ

投稿2021/11/23 09:38

編集2021/11/23 09:47

ダイアログのテキストフィールドで変更した値を呼び出し元のWidgetに反映させたい

別ファイルのJSONで管理している文字列を表示した画面から、その値を編集するテキストフィールドが入ったダイアログを呼び出して値を変更させダイアログを閉じた後に、呼び出し元の画面に映っている文字列が自動で更新されるようにしたいです。
以下のサイトを参考にしましたが、Flutter初心者なため内容が全然わかりませんでした。(特にtime_bloc.dartの仕組みが全然わかりません。。。)
一体何から手を付けていいのかわからない状況です。
よろしくお願いします。

Navigator.pushで画面遷移として新しくWidgetを作ると呼び出し元の画面値は変わるのですが、そうではなく、テキストフィールドで編集した別ファイルのStringをダイアログを消した瞬間に画面が自動で再度読み込みしたりして映している文字列を変えるようにしたいです。

参考にしたサイト

Flutter:ダイアログで入力した値を呼び出し元の画面に渡す

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

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

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

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

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

guest

回答1

0

ベストアンサー

showDialogをpopするときに、Navigator.pop(context, 'test')のように引数を追加すると、それを返すようになります。
例ではStringを返していますので、以下のようにすれば呼び出したWidgetで取得できます。

dart

1// showDialog呼び出し 2onTap: () async { 3 String value = await showDialog( 4 context: context, 5 builder: (context) { 6 String response = 'test'; 7 return TextButton( 8 onPressed: () => Navigator.pop(context, response), // ここで返すデータを指定 9 child: const Text('OK'), 10 ); 11 }, 12 ); 13 14 print(value); // 'test' 15 16 setState(() { 17 responseString = value; // ここでresponseStringに代入して、再描画 18 }); 19},

showDialogの戻り値はFuture<T?>です。この<T?>は、 Navigator.popの2つめの引数の型になります。
Futureなので、awaitで受け取る必要があり、そのためにはファンクションにasyncを付けないといけません。

サンプルのように、専用のファンクションを作ってラップして使うのが楽かも。

投稿2021/12/08 05:38

Yasha_Wedyue

総合スコア830

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問