Flutter 如何制作像Google这样的TextFormField?

Flutter 如何制作像Google这样的TextFormField?,flutter,mobile,mobile-development,Flutter,Mobile,Mobile Development,我对TextField在flatter上注册Google帐户的实现感兴趣。我如何从一个日期生成一系列类似的文本字段,其中所有三个字段都有一个errorText,当它们单击“next”时,三个字段将同时被选中,如果没有输入一个字段,则所有字段都将变为红色,即使它们是正确的。它就像是三个中的一个 对于大纲文本字段,您可以使用 TextField( decoration: new InputDecoration( border: new OutlineInputBorder(),

我对TextField在flatter上注册Google帐户的实现感兴趣。我如何从一个日期生成一系列类似的文本字段,其中所有三个字段都有一个errorText,当它们单击“next”时,三个字段将同时被选中,如果没有输入一个字段,则所有字段都将变为红色,即使它们是正确的。它就像是三个中的一个


对于大纲文本字段,您可以使用

TextField(
  decoration: new InputDecoration(
      border: new OutlineInputBorder(),
      filled: true,
      hintText: "Type in your text",
   ),
)
对于验证,实现它的最佳方法是使用 和
TextFormField
而不是
TextField

例如:

import 'package:flutter/material.dart';

void main() => runApp(MyApp());

class MyApp extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    final appTitle = 'Form Validation Demo';

    return MaterialApp(
      title: appTitle,
      home: Scaffold(
        appBar: AppBar(
          title: Text(appTitle),
        ),
        body: MyCustomForm(),
      ),
    );
  }
}

// Create a Form widget.
class MyCustomForm extends StatefulWidget {
  @override
  MyCustomFormState createState() {
    return MyCustomFormState();
  }
}

// Create a corresponding State class.
// This class holds data related to the form.
class MyCustomFormState extends State<MyCustomForm> {
  // Create a global key that uniquely identifies the Form widget
  // and allows validation of the form.
  //
  // Note: This is a GlobalKey<FormState>,
  // not a GlobalKey<MyCustomFormState>.
  final _formKey = GlobalKey<FormState>();

  String _firstName;
  String _lastName;

  @override
  Widget build(BuildContext context) {
    // Build a Form widget using the _formKey created above.
    return Form(
      key: _formKey,
      child: Column(
        crossAxisAlignment: CrossAxisAlignment.start,
        children: <Widget>[
          TextFormField(
            validator: (value) {
              if (value.isEmpty) {
                return 'Please enter some text';
              }
              return null;
            },
            onSaved: (val) => _firstName = val,
          ),
          TextFormField(
            validator: (value) {
              if (value.isEmpty) {
                return 'Please enter some text';
              }
              return null;
            },
            onSaved: (val) => _lastName = val,
          ),
          Padding(
            padding: const EdgeInsets.symmetric(vertical: 16.0),
            child: RaisedButton(
              onPressed: () {
                // Validate returns true if the form is valid, or false
                // otherwise.
                final form = _formKey.currentState;
                if (form.validate()) {
                  form.save();
                  // If the form is valid, display a Snackbar.
                  Scaffold.of(context).showSnackBar(SnackBar(
                      content: Text('The result: $_firstName, $_lastName')));
                }
              },
              child: Text('Submit'),
            ),
          ),
        ],
      ),
    );
  }
}
导入“包装:颤振/材料.省道”;
void main()=>runApp(MyApp());
类MyApp扩展了无状态小部件{
@凌驾
小部件构建(构建上下文){
最终appTitle='表单验证演示';
返回材料PP(
标题:appTitle,
家:脚手架(
appBar:appBar(
标题:文本(appTitle),
),
正文:MyCustomForm(),
),
);
}
}
//创建一个表单小部件。
类MyCustomForm扩展了StatefulWidget{
@凌驾
MyCustomFormState createState(){
返回MyCustomFormState();
}
}
//创建相应的状态类。
//此类保存与表单相关的数据。
类MyCustomFormState扩展了状态{
//创建唯一标识表单小部件的全局键
//并允许对表单进行验证。
//
//注意:这是一个GlobalKey,
//不是通俗的。
final _formKey=GlobalKey();
字符串_firstName;
字符串_lastName;
@凌驾
小部件构建(构建上下文){
//使用上面创建的_formKey构建表单小部件。
报税表(
键:_formKey,
子:列(
crossAxisAlignment:crossAxisAlignment.start,
儿童:[
TextFormField(
验证器:(值){
if(value.isEmpty){
返回“请输入一些文本”;
}
返回null;
},
onSaved:(val)=>_firstName=val,
),
TextFormField(
验证器:(值){
if(value.isEmpty){
返回“请输入一些文本”;
}
返回null;
},
onSaved:(val)=>\u lastName=val,
),
填充物(
填充:常量边集。对称(垂直:16.0),
孩子:升起按钮(
已按下:(){
//如果表单有效,则Validate返回true,否则返回false
//否则。
最终形式=_formKey.currentState;
if(form.validate()){
form.save();
//如果表单有效,则显示一个快捷键。
Scaffold.of(上下文).showSnackBar(SnackBar(
内容:文本(“结果:$\u firstName,$\u lastName”);
}
},
子项:文本('Submit'),
),
),
],
),
);
}
}

很酷,伙计。谢谢。但这不是我需要的。如何从三个textformfield中立即获取这三个字段的验证器后的一个文本?(与屏幕截图中的前三个字段一样,每个字段都有一个错误文本)还有,我如何在errorText中创建与同一屏幕截图相同的图标?在这种情况下,您可能需要直接扩展
FormField
并自己控制错误的可见性,有关实现示例,请参见
TextFormField
。但是没有现成的小部件可以用相同的样式按照您的需要执行错误。我已经更新了我的示例来展示如何连接结果。可能是人。除了这个地方,我能接到你的回电吗?