この記事はこんな人におすすめ!
- FlutterのTextFieldで入力フォームを実装したい
- TextFieldで入力した値を取得する方法が知りたい
「Flutterで入力フォームを作成するにはどうするの?」
今回はFlutterで入力フォームを実装できるTextField
の使い方を解説していきます。本記事の内容はFluter公式のCookbookの手順を参考にしています。
目次
TextFieldとは?
TextField
は入力フォームを実装できるウィジェットです。メールアドレスや名前などユーザーから取得したい場合などに使用できます。
ステップ1:TextEditingControllerの作成
それではTextField
の使い方を紹介していきます。
まずはStatefulWidget
でTextEditingController
とdispose
メソッドを次のように作成します。
今回は_myController
でTextEditingController
を定義しています。
class MyHomePage extends StatefulWidget {
const MyHomePage({super.key});
@override
State<MyHomePage> createState() => _MyHomePageState();
}
class _MyHomePageState extends State<MyHomePage> {
final _myController = TextEditingController();
@override
void dispose() {
_myController.dispose();
super.dispose();
}
@override
Widget build(BuildContext context) {
return ...
}
}
ステップ2:TextFieldとTextEditingControllerを連携させる
次にTextField
のcontroller
プロパティの引数に先ほど定義した_myController
を渡せば入力フォームの完成です。
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(title: const Text('Flutter')),
body: TextField(
controller: _myController,
),
);
}
ステップ3:入力フォームで入力した値を取得
入力した値を取得するには先ほど定義したTextEditingController
のtext
プロパティを使用します。
次のコードではAlertDialog
でTextEditingController.text
を表示しています。
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(title: const Text('Flutter')),
body: TextField(
controller: _myController,
),
floatingActionButton: FloatingActionButton(
onPressed: () {
showDialog(
context: context,
builder: (context) {
return AlertDialog(
content: Text(_myController.text),
);
},
);
},
child: const Icon(Icons.text_fields),
),
);
}
サンプルコード
import 'package:flutter/material.dart';
void main() => runApp(const MyApp());
class MyApp extends StatelessWidget {
const MyApp({super.key});
@override
Widget build(BuildContext context) {
return MaterialApp(
home: MyHomePage(),
);
}
}
class MyHomePage extends StatefulWidget {
const MyHomePage({super.key});
@override
State<MyHomePage> createState() => _MyHomePageState();
}
class _MyHomePageState extends State<MyHomePage> {
final myController = TextEditingController();
@override
void dispose() {
myController.dispose();
super.dispose();
}
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(title: const Text('Flutter')),
body: Center(
child: TextField(
controller: myController,
),
),
floatingActionButton: FloatingActionButton(
onPressed: () {
showDialog(
context: context,
builder: (context) {
return AlertDialog(
content: Text(myController.text),
);
},
);
},
child: const Icon(Icons.text_fields),
),
);
}
}
まとめ
今回はTextField
を使用して入力フォームを実装する方法を紹介します。TextField
に似たTextFormField
もあるのでぜひ一緒にチェックしてみてください。