取得文字欄位 (text field) 的值
在本教學中, 你將學習如何透過以下步驟, 取得使用者在文字欄位 (text field) 中輸入的文字:
- 建立
TextEditingController。 - 將
TextEditingController提供給TextField。 - 顯示目前文字欄位 (text field) 的值。
1. 建立TextEditingController
#若要取得使用者在文字欄位 (text field) 中輸入的文字, 請建立一個TextEditingController, 並將其提供給TextField或TextFormField。
dart
// Define a custom Form widget.
class MyCustomForm extends StatefulWidget {
const MyCustomForm({super.key});
@override
State<MyCustomForm> createState() => _MyCustomFormState();
}
// Define a corresponding State class.
// This class holds the data related to the Form.
class _MyCustomFormState extends State<MyCustomForm> {
// Create a text controller and use it to retrieve the current value
// of the TextField.
final myController = TextEditingController();
@override
void dispose() {
// Clean up the controller when the widget is disposed.
myController.dispose();
super.dispose();
}
@override
Widget build(BuildContext context) {
// Fill this out in the next step.
}
}2. 將 TextEditingController 提供給 TextField
#現在你已經有了一個 TextEditingController,接下來請使用 controller 屬性,將它連接到一個文字欄位 (text field) 上:
dart
return TextField(controller: myController);3. 顯示文字欄位 (text field) 的目前值
#在將 TextEditingController 提供給文字欄位 (text field) 之後, 即可開始讀取其值。使用 TextEditingController 所提供的 text 屬性來取得使用者在文字欄位中輸入的字串 (String)。
以下程式碼會在使用者點擊浮動操作按鈕(floating action button)時, 以警示對話框顯示文字欄位目前的值。
dart
FloatingActionButton(
// When the user presses the button, show an alert dialog containing
// the text that the user has entered into the text field.
onPressed: () {
showDialog(
context: context,
builder: (context) {
return AlertDialog(
// Retrieve the text that the user has entered by using the
// TextEditingController.
content: Text(myController.text),
);
},
);
},
tooltip: 'Show me the value!',
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 const MaterialApp(
title: 'Retrieve Text Input',
home: MyCustomForm(),
);
}
}
// Define a custom Form widget.
class MyCustomForm extends StatefulWidget {
const MyCustomForm({super.key});
@override
State<MyCustomForm> createState() => _MyCustomFormState();
}
// Define a corresponding State class.
// This class holds the data related to the Form.
class _MyCustomFormState extends State<MyCustomForm> {
// Create a text controller and use it to retrieve the current value
// of the TextField.
final myController = TextEditingController();
@override
void dispose() {
// Clean up the controller when the widget is disposed.
myController.dispose();
super.dispose();
}
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(title: const Text('Retrieve Text Input')),
body: Padding(
padding: const EdgeInsets.all(16),
child: TextField(controller: myController),
),
floatingActionButton: FloatingActionButton(
// When the user presses the button, show an alert dialog containing
// the text that the user has entered into the text field.
onPressed: () {
showDialog(
context: context,
builder: (context) {
return AlertDialog(
// Retrieve the text the that user has entered by using the
// TextEditingController.
content: Text(myController.text),
);
},
);
},
tooltip: 'Show me the value!',
child: const Icon(Icons.text_fields),
),
);
}
}