知っておくべきTextFieldのfocusの扱い方3選【Flutter】

image

はじめに

今回は、FlutterのTextFieldのfocusについて説明していきたいと思います。
この記事では、以下の3つについて紹介したいと思います。

  • TextFieldに自動でfocusを当てる方法
  • 画面の他の部分をタップすると、TextFieldからfocusをはずす方法
  • 次のTextFieldへ自動でfocusを移す方法

この3つをマスターすれば、開発中にTextFieldのfocusで困ることはほとんどなくなるはずです。
TextFieldよりもTextFormFieldの方が使う機会が多いと思うので、例ではTextFormFieldを使用します。

TextFieldに自動でfocusを当てる方法

autofocus = trueで画面が描画されたタイミングで、自動でフォーカスが当たるようになります。
これは簡単!

autofocus

以下がサンプルコードです。

TextFormField(
autofocus: true, //ここ
decoration: InputDecoration( contentPadding: EdgeInsets.symmetric(horizontal: 16)), ),

画面の他の部分をタップでTextFieldからfocusをはずす方法

TextField以外の部分をタップすることで、フォーカスを外したい(キーボードを閉じたい)場面ってよくありますよね。 複数行が入力できるフォームだと、画面タップでfocusが外せないと、
「キーボードが閉じれない!!!」
なんてこともよく起こります..

request focus

こちらも結構すんなり実装できますよ。
こちらがサンプルコードです。

    final focusNode = FocusNode();
    return Focus(
      focusNode: focusNode,
      child: GestureDetector(
        onTap: focusNode.requestFocus,
        child: Scaffold(
          resizeToAvoidBottomInset: false, //キーボードによって画面サイズを変更させないため
          appBar: AppBar(title: Text('画面タップでフォーカスを外す'),),
          body: Center(
            child: TextFormField(),
          ),
        ),
      ),
    );

フォーカスを外すための手順

  • 画面のおおもとをFocusでラップする。
  • フォーカスを外すために、タップする部分をGestureDetectorでラップする。
  • GestureDetectoronTapFocusNode.requestFocusをする。

これだけです! TextFieldの中では何もする必要がないのです。
FocusNode.requestFocusによって、TextFieldのフォーカスが、画面のおおもとをラップしたFocusへ移ります。

次のTextFieldへ自動でfocusを移す方法

名前・住所・電話番号...
など複数の情報の入力フォームを作る際には、自動でフォーカスが移動した方が、ユーザーはきっと嬉しいはずです。
UXを向上させるためにも、毎回意識しておいた方がいいポイントですね。

これも簡単です。
TextFieldtextInputActionTextInputAction.nextを設定するだけです。
TextInputAction.nextを指定してやるだけで、次のTextFieldに自動でfocusが移動します。

move focus

        Column(
          children: [
            TextFormField(
textInputAction: TextInputAction.next,
decoration: InputDecoration( hintText: '1', contentPadding: EdgeInsets.symmetric(horizontal: 16)), ), TextFormField(
textInputAction: TextInputAction.next,
decoration: InputDecoration( hintText: '2', contentPadding: EdgeInsets.symmetric(horizontal: 16)), ), TextFormField(
textInputAction: TextInputAction.done,
decoration: InputDecoration( hintText: '3', contentPadding: EdgeInsets.symmetric(horizontal: 16)), ), ], )

3つ目のTextFieldは、TextInputAction.doneをセットしているので、入力完了時にfocusが外れるようになっています。  

最後に

いかがでしたか。
FlutterでのTextFieldのfocus関連はマスターできましたでしょうか。
参考になれば幸いです。

参考

https://api.flutter.dev/flutter/material/TextFormField-class.html https://stackoverflow.com/questions/52150677/how-to-shift-focus-to-next-textfield-in-flutter

お知らせ

可茂IT塾ではFlutter/Reactのインターンを募集しています!

可茂IT塾ではFlutter/Reactのインターンを募集しています!

可茂IT塾ではFlutter/Reactのインターンを募集しています!可茂IT塾のエンジニアの判断で、一定以上のスキルをを習得した方には有給でのインターンも受け入れています。

Read More
U30可茂ITインターンハッカソン

U30可茂ITインターンハッカソン

12月28,29日開催。2日間でアプリ開発の企画から完成までを目指す!U30可茂ITインターンハッカソンを開催します。

Read More

タグ

Flutter (118)初心者向け (29)イベント (18)Google Apps Script (16)Nextjs (12)可茂IT塾 (10)React (8)Firebase (7)riverpod (6)ChatGPT (5)vscode (5)デザイン (5)新卒 (4)就活 (4)Figma (4)Dart (4)JavaScript (4)お知らせ (4)FlutterWeb (3)Prisma (3)NestJS (3)Slack (3)TypeScript (3)ワーケーション (3)インターン (3)設計 (2)線型計画法 (2)事例 (2)Git (2)Image (2)File (2)Material Design (2)経験談 (2)画像 (2)iOS (2)アプリ開発 (2)React Hooks (2)tailwindcss (2)社会人 (2)大学生 (2)RSS (1)Google (1)Web (1)CodeRunner (1)個人開発 (1)Android (1)Unity (1)WebView (1)Twitter (1)フルリモート (1)TextScaler (1)textScaleFactor (1)学生向け (1)supabase (1)Java (1)Spring Boot (1)shell script (1)正規表現 (1)table (1)テーブル (1)hooks (1)react (1)パワーポイント (1)趣味 (1)モンスターボール (1)CSS (1)SCSS (1)Cupertino (1)ListView (1)就活浪人 (1)既卒 (1)保守性 (1)iPad (1)シェアハウス (1)スクレイピング (1)PageView (1)画面遷移 (1)flutter_hooks (1)Gmail (1)GoogleWorkspace (1)ShaderMask (1)google map (1)Google Places API (1)GCPコンソール (1)Google_ML_Kit (1)Vercel (1)Google Domains (1)DeepLeaning (1)深層学習 (1)Google Colab (1)コード生成 (1)GitHub Copilot (1)オンラインオフィス (1)javascript (1)css (1)html (1)オブジェクト指向 (1)クラスの継承 (1)ポリモーフィズム (1)LINE (1)Bitcoin (1)bitFlyer (1)コミュニティー (1)文系エンジニア (1)build_runner (1)freezed (1)Freezed (1)ヒーター (1)作業効率 (1) (1)Flutter実践開発 (1) (1)permission_handler (1)flutter_local_notifications (1)markdown (1)GlobalKey (1)ValueKey (1)Key (1)アイコン (1)go_router (1)FireStorage (1)debug (1)datetime_picker (1)Apple Store Connect (1)FlutterGen (1)デバッグ (1)Widget Inspector (1)VRChat (1)API (1)検索機能 (1)Shader (1)Navigator (1)メール送信 (1)FlutterFlow (1)Firebase App Distribution (1)Fastlane (1)Dio (1)CustomClipper (1)ClipPath (1)カスタム認証 (1)アニメーション (1)Arduino (1)ESP32 (1)フリーランス (1)会社員 (1)mac (1)csv (1)docker (1)GithubActions (1)Dialog (1)BI (1)LifeHack (1)ショートカット (1)Chrome (1)高校生 (1)キャリア教育 (1)非同期処理 (1)生体認証 (1)BackdropFilter (1)レビュー (1)getAuth (1)クローズドテスト (1)PlayConsole (1)Algolia (1)コンサルティング (1)Symbol (1)

お知らせ

可茂IT塾ではFlutter/Reactのインターンを募集しています!

可茂IT塾ではFlutter/Reactのインターンを募集しています!

可茂IT塾ではFlutter/Reactのインターンを募集しています!可茂IT塾のエンジニアの判断で、一定以上のスキルをを習得した方には有給でのインターンも受け入れています。

Read More
U30可茂ITインターンハッカソン

U30可茂ITインターンハッカソン

12月28,29日開催。2日間でアプリ開発の企画から完成までを目指す!U30可茂ITインターンハッカソンを開催します。

Read More