2021-12-27に投稿

Flutterでラジオボタンのバリデーションを行う

Flutterのラジオボタンにはvalidatorがない。そもそもラジオボタングループのようなウィジェットもない。

ではラジオボタンもFormの _formKey.currentState!.validate() でバリデーションさせたい時にはどうしたらよいか。

Flutter FormBuilderというパッケージにそういうのがあるのでそれを使うと簡単。

flutter_form_builder | Flutter Package

FormBuilderRadioGroup<String>(
    name: 'gender',
    decoration: const InputDecoration(
      contentPadding: EdgeInsets.zero,
      border: InputBorder.none,
    ),
    onChanged: onGenderChanged,
    validator: (value) {
      if (value == null || value.isEmpty) {
        return '性別を選択してください。';
      }
      return null;
    },
    options: const [
      FormBuilderFieldOption(value: 'man', child: Text('男性')),
      FormBuilderFieldOption(value: 'woman', child: Text('女性')),
    ],
  )

デフォルトだとラッパーの枠がつくのでdecorationのborderで消している。

あとはデフォルト選択で良ければいちいちバリデーションを入れずにそれでも良いような気もする。

ちなみにどうしてもカスタマイズが必要な場合は下記のように自作も可能。

Flutterでバリデーションに対応したカスタムなフィールドを作成する

ツイッターでシェア
みんなに共有、忘れないようにメモ

だら@Crieit開発者

Crieitの開発者です。 Webエンジニアです(在宅)。大体10年ちょい。 記事でわかりにくいところがあればDMで質問していただくか、案件発注してください。 業務依頼、同業種の方からのコンタクトなどお気軽にご連絡ください。 業務経験有:PHP, MySQL, Laravel, React, Flutter, Vue.js, Node, RoR 趣味:Elixir, Phoenix, Nuxt, Express, GCP, AWS等色々 PHPフレームワークちいたんの作者

Crieitは誰でも投稿できるサービスです。 是非記事の投稿をお願いします。どんな軽い内容でも投稿できます。

また、「こんな記事が読みたいけど見つからない!」という方は是非記事投稿リクエストボードへ!

有料記事を販売できるようになりました!

こじんまりと作業ログやメモ、進捗を書き残しておきたい方はボード機能をご利用ください。
ボードとは?

コメント