微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

Flutter:如何将 Textfield 输入放入列表以构建 ListView.builder

如何解决Flutter:如何将 Textfield 输入放入列表以构建 ListView.builder

我几天以来一直在尝试构建一个列表视图构建器。为此,我需要从另一个屏幕输入文本字段。我看了很多教程和问题,但它不起作用。我试图将来自多个文本字段的输入放入多个列表以构建一个 Listview 构建器。如果我可以在按下 flatbutton 时保存所有文本字段输入,那将是最好的。我希望有人可以帮助我。

第一页

List<String> time = ["8:00"];List<String> 
List<String> where = ["Am See"];
List<String> who = ["Eric"];
List<String> when = ["Donnerstag 21.4.21"];






body: SingleChildScrollView(
            physics: ScrollPhysics(),child: Column(children: [
              Upperscreen(size: size),ListView.builder(
                  physics: NeverScrollableScrollPhysics(),shrinkWrap: true,itemCount: where.length,itemBuilder: (BuildContext context,int Index) {
                    return Column(children: [
                      SizedBox(
                        height: 40,),Container(
                          child: GestureDetector(
                              onTap: () {
                                Navigator.push(
                                    context,MaterialPageRoute(
                                        builder: (context) => Meet1()));
                              },child: Container(
                                  width: size.width * 0.9,decoration: Boxdecoration(
                                    borderRadius: BorderRadius.all(
                                        Radius.circular(70)),gradient: LinearGradient(
                                      begin: Alignment.topRight,end: Alignment.bottomright,colors: [
                                        Colors.green,Colors.orange,],child: Column(children: <Widget>[
                                    SizedBox(
                                      height: 10,Padding(
                                      padding: EdgeInsets.all(20),child: Column(
                                        children: <Widget>[
                                          Text(
                                            time[Index],style: TextStyle(
                                                color: Colors.white,fontSize: 40,fontWeight:
                                                    FontWeight.bold),SizedBox(
                                            height: 10,Text(
                                            who[Index],fontSize: 20,Text(
                                            when[Index],Text(
                                            where[Index],

第二页

child: Column(children: <Widget>[
      SizedBox(
        height: 10,Padding(
        padding: EdgeInsets.all(20),child: Column(
          children: <Widget>[
            TextField(decoration: Inputdecoration(hintText: " Time ")),SizedBox(
              height: 10,TextField(
              decoration: Inputdecoration(hintText: " Who "),TextField(
              decoration: Inputdecoration(hintText: " Date "),TextField(
              decoration: Inputdecoration(hintText: " Where "),SizedBox(height: 10)
          ],]));

这里是要添加所有内容的 Flatbutton。

return FlatButton(
  child: Icon(
    Icons.check_circle_outline_rounded,color: Colors.green,size: 120,onpressed: () {
    Navigator.of(context).popUntil((route) => route.isFirst);
  },

解决方法

使用 TextEditingController(),就像这样 -

TextEditingController() myController = TextEditingController();

然后将此控制器分配给TextField()中的控制器属性-

TextField(
  controller: myController,),

然后使用myController.textTextField()中检索文本,并将其作为String参数传递给其他页面-

示例 -

class Screen1 extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return Scaffold(
      //....
      body: FlatButton(
        child: Icon(
        Icons.check_circle_outline_rounded,color: Colors.green,size: 120,onPressed: () {
            Navigator.push(context,MaterialPageRoute(builder: (builder) {
                 return Screen2(text: myController.text);
            }));
         },//....
     ),);
  }
}

第二页 -

class Screen2 extends StatelessWidget {
  
  String text;
  Screen2({this.text});
  
  @override
  Widget build(BuildContext context) {
    return Scaffold(
      //....
      body: Text(text),);
  }
}

Go to this link to see another example

现在,我在这里只使用了 1 个参数“文本”。您可以根据需要使用多个参数,例如“text1”、“text2”、“text3”等,并为此使用尽可能多的 TextEditingController()

*****另请注意,FlatButton() 的使用已折旧,您可以使用 TextButton() 代替

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?