Как установить поля TextFormFields и контроллеры в динамических картах с помощью конструктора Listview
Я пытаюсь создать каждую карту с полями текстовой формы при нажатии кнопки, пока она не достигнет некоторого предела, например, только 10 карт. Поэтому, когда я нажал плавающую кнопку, карта добавляется, но текст в полях текстовой формы стирается при каждом нажатии. Может ли кто-нибудь помочь мне динамически создавать карты с текстовыми полями без стирания при каждом нажатии? Ниже прилагаю скриншоты приложения.
import 'package:flutter/material.dart';
void main() {
runApp(App());
}
class App extends StatelessWidget {
@override
Widget build(BuildContext context) {
return MaterialApp(
home: CardWithTextformfield(),
);
}
}
class CardWithTextformfield extends StatefulWidget {
const CardWithTextformfield({Key? key}) : super(key: key);
@override
_CardWithTextformfieldState createState() => _CardWithTextformfieldState();
}
class _CardWithTextformfieldState extends State<CardWithTextformfield> {
var name =<TextEditingController>[];
var id =<TextEditingController>[];
var addCard =0;
void incrementcard(){
setState(() {
if(addCard >=7){
return;
}
addCard++;
});
}
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(
title: Text('Card with TextformField'),
),
floatingActionButton: FloatingActionButton(
onPressed: incrementcard,
child: Icon(Icons.add),
),
body: Container(
child:ListView.builder(
itemCount: addCard,
itemBuilder: (context,index){
return cardslist();
}
),
),
);
}
Widget cardslist(){
var nameController = TextEditingController();
var idController = TextEditingController();
name.add(nameController);
id.add(idController);
return Card(
margin: EdgeInsets.all(10),
child: Container(
child: Column(
children: [
Row(
mainAxisAlignment: MainAxisAlignment.spaceBetween,
children: [
Container(
margin: EdgeInsets.all(10),
child: Text('Name: ')),
Expanded(child: TextFormField(
controller: nameController,
decoration: InputDecoration(hintText: 'Name'),
),),
Container(
margin: EdgeInsets.all(10),
child: Text('EmpId: '),),
Expanded(child: TextFormField(
controller: idController,
decoration: InputDecoration(hintText: 'EmpId'),
),),
],
),
],
),
),
);
}
}
1 ответ
Проблема с вашим подходом заключается в том, что вы воссоздаете каждый контроллер при вставке новой карты, поэтому введенные значения теряются. Вместо этого вы должны проверить, существуют ли уже контроллеры в вашем массиве для текущей карты, и если да, использовать существующие контроллеры, в противном случае создать новые.
Для этого вам нужно добавить
index
в качестве параметра для вашего
cardsList
метод. Я думаю, что приведенный ниже код решит вашу проблему.
Важно : контроллеры должны быть уничтожены при уничтожении этого виджета, пожалуйста, добавьте эту часть. Вы должны переопределить
dispose
метод в вашем
_CardWithTextformfieldState
, переберите все ваши контроллеры в обоих массивах и вызовите
dispose()
на каждом контроллере. В конце не забудьте позвонить
super.dispose()
.
import 'package:flutter/material.dart';
void main() {
runApp(App());
}
class App extends StatelessWidget {
@override
Widget build(BuildContext context) {
return MaterialApp(
home: CardWithTextformfield(),
);
}
}
class CardWithTextformfield extends StatefulWidget {
const CardWithTextformfield({Key? key}) : super(key: key);
@override
_CardWithTextformfieldState createState() => _CardWithTextformfieldState();
}
class _CardWithTextformfieldState extends State<CardWithTextformfield> {
final _name = <TextEditingController>[];
final _id = <TextEditingController>[];
int _addCard = 0;
void _incrementcard() {
setState(() {
if (_addCard >= 7) {
return;
}
_addCard++;
});
}
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(
title: Text('Card with TextformField'),
),
floatingActionButton: FloatingActionButton(
onPressed: _incrementcard,
child: Icon(Icons.add),
),
body: Container(
child: ListView.builder(
itemCount: _addCard,
itemBuilder: (context, index) {
return cardslist(index);
}),
),
);
}
Widget cardslist(int index) {
if (_name.length <= index) {
_name.add(TextEditingController());
_id.add(TextEditingController());
}
return Card(
margin: EdgeInsets.all(10),
child: Container(
child: Column(
children: [
Row(
mainAxisAlignment: MainAxisAlignment.spaceBetween,
children: [
Container(margin: EdgeInsets.all(10), child: Text('Name: ')),
Expanded(
child: TextFormField(
controller: _name[index],
decoration: InputDecoration(hintText: 'Name'),
),
),
Container(
margin: EdgeInsets.all(10),
child: Text('EmpId: '),
),
Expanded(
child: TextFormField(
controller: _id[index],
decoration: InputDecoration(hintText: 'EmpId'),
),
),
],
),
],
),
),
);
}
}