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

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

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

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

Dart

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

解決済

【Flutter】Stepperの内容を受け取った文字列によって変えたい

my0930
my0930

総合スコア19

Flutter

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

Dart

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

1回答

0リアクション

0クリップ

150閲覧

投稿2022/10/01 07:47

編集2022/10/01 08:04

前提

Stepperウィジェットで手順画面を作ろうと思っています。

実現したいこと

要約すると
stepsプロパティの値を動的に変更できて、前ページからもらった値によって変更できるか

Providerを使ってmodelの値(現段階で考えているのはString値)を受け取り、
値渡しをしていま受け取っている値によって、
Stepperのstepsプロパティの値を変えることで
表示の中身を変えたい。

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

強いて言うなら The argument type 'String?' can't be assigned to the parameter type 'List<Step>'.

該当のソースコード

main

class WorkStepPage extends StatefulWidget { WorkStepPage( {Key? key, required this.workname, required this.phase, required this.documentId}) : super(key: key); final String workname; final int phase; final String documentId; @override State<WorkStepPage> createState() => _WorkStepPageState(); } class _WorkStepPageState extends State<WorkStepPage> with SingleTickerProviderStateMixin { late int currentStep = int.parse(widget.phase.toString()); List<Step> cleanSteps = [ Step( isActive: true, title: Text("用具の準備"), content: Container(), ), Step( isActive: true, title: Text("濡れ拭き"), content: Container(), ), Step( isActive: true, title: Text("乾拭き"), content: Container(), ), Step( isActive: true, title: Text("ゴミ捨て"), content: Container(), ), Step( isActive: true, title: Text("用具の片付け"), content: Container(), ), ]; List<Step> programnSteps = [ Step( isActive: true, title: Text("エディター起動"), content: Container(), ), Step( isActive: true, title: Text("コーディング"), content: Container(), ), Step( isActive: true, title: Text("ビルド"), content: Container(), ), Step( isActive: true, title: Text("デバッグ"), content: Container(), ), Step( isActive: true, title: Text("リファクタリング"), content: Container(), ), ]; @override Widget build(BuildContext context) { return ChangeNotifierProvider<WorkStepModel>( create: (_) => WorkStepModel(), child: Consumer<WorkStepModel>( builder: (context, model, child) { return Scaffold( appBar: AppBar(), body: Center( child: Stepper( steps: (model.workName),     //ここを可変にしたい currentStep: currentStep, type: StepperType.vertical, // onStepTapped: (step) { // setState(() { // currentStep = step; // }); // }, onStepCancel: () { setState( () { if (currentStep > 0) { currentStep = currentStep - 1; } else { currentStep = 0; } }, ); }, onStepContinue: () { setState( () { if (currentStep < cleanSteps.length - 1) { currentStep = currentStep + 1; } else { currentStep = 0; } }, ); }, ), ), ); }, ), ); } }

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

Flutter 3.0.5

以下のような質問にはリアクションをつけましょう

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

リアクションが多い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

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

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

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

下記のような質問は推奨されていません。

  • 間違っている
  • 質問になっていない投稿
  • スパムや攻撃的な表現を用いた投稿

適切な質問に修正を依頼しましょう。

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

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

アカウントをお持ちの方は

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

ただいまの回答率
86.12%

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

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

質問する

関連した質問

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

Flutter

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

Dart

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