具有默认文本的TextFormField

时间:2018-09-12 12:23:21

标签: dart flutter

我想拥有一些FormTextFields,其中包含一些用户可以更改的默认文本。 我的问题是,修改了字段后,如果按一下另一个字段或按钮,一切都很好,但是,如果按键盘上的“完成”按钮,则会返回默认文本,删除用户插入的新内容。这是我到目前为止所做的:

class _LoginSettingsViewState extends State<LoginSettingsView> {

  final GlobalKey<FormState> _formKey = new GlobalKey<FormState>();

  var _userTextController = new TextEditingController();

@override
  Widget build(BuildContext context) {

    _userTextController.text = "test";

 return Scaffold(

      appBar: AppBar(
        title: Text("Settings"),
      ),

      body: ListView(
        children: <Widget>[
          new Container(
            margin: EdgeInsets.only(
              left: 10.0,
              right: 10.0,
              top: MediaQuery.of(context).size.height / 10
            ),
            child: Form(
                key: _formKey,
                child: Column(
                  children: <Widget>[
                    TextFormField(
                      decoration: _fieldDecoration("user", null),
                      controller: _userTextController,
                      validator: (val) => val.isEmpty ? "Insert user" : null,
                      onSaved: (val){
                        print(val);
                      },
                    ),

1 个答案:

答案 0 :(得分:3)

您要在构建方法中设置默认文本,每次重新构建UI时,都会调用该构建方法,以便您放回默认文本。

initState方法内进行初始化

@override
void initState() {
  super.initState();
  _userTextController.text = "test";
}

也不要忘记布置控制器

@override
void dispose() {
  _userTextController.dispose();
  super.dispose();
}