【发布时间】:2019-12-11 04:58:42
【问题描述】:
我正在努力提高对 Flutter 的理解,并且正在努力解决一个问题。我正在尝试创建一个应用程序,该应用程序显示从列表中提取数据的卡片列表。底部有一个按钮,当用户单击它时会创建一张新卡片。
我试图让每张卡片显示一个唯一的“整数”。因此,例如,每次用户单击按钮时,都会添加一张卡片,该卡片会在单词“Round”旁边显示序号。第 1 轮 > 第 2 轮 > 第 3 轮,依此类推。
现在一切正常,只是每次按下按钮时,所有卡片都会更新为最新数字。因此,每张卡都更新为最新的轮数,而不是获取卡的顺序列表。
我做错了什么?谢谢。
这是我的代码:
import 'package:flutter/material.dart';
class Round {
int roundNumber;
int firstNumber;
int secondNumber;
Round({ this.roundNumber, this.firstNumber, this.secondNumber, });
}
int uid = 1;
List<Round> roundsList = [
Round(roundNumber: uid, firstNumber: 1, secondNumber: 2),
];
class createLevels extends StatefulWidget {
@override
_createLevelsState createState() => _createLevelsState();
}
class _createLevelsState extends State<createLevels> {
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(
centerTitle: true,
title: Text("Create Rounds",)
),
body: Padding(
padding: const EdgeInsets.fromLTRB(20, 20, 20.0, 20),
child: Container(
child: Column(
children: <Widget>[
Expanded(
child: ListView.builder(
itemCount: roundsList.length,
itemBuilder: (BuildContext context, int whatIsThisVariable) {
return roundCard(Round(roundNumber: uid, firstNumber: 2, secondNumber: 3,));
}
),
),
Text("$roundsList"),
RaisedButton(
onPressed: () {
uid++;
roundsList.add(Round(roundNumber: uid));
setState(() {});
},
child: Text("Add Round"),
),
],
),
),
),
);
}
}
class roundCard extends StatelessWidget {
final Round round;
roundCard(this.round);
// roundsList.add(Round(roundNumber: 1));
@override
Widget build(BuildContext context) {
return Container(
child: Card(
child: Padding(
padding: const EdgeInsets.all(8.0),
child: Row(
mainAxisAlignment: MainAxisAlignment.spaceEvenly,
children: <Widget>[
Spacer(
flex: 1,
),
Expanded(
child: Text('Round ${round.roundNumber}:'),
flex: 12,
),
Expanded(
child: TextFormField(
textAlign: TextAlign.center,
decoration: InputDecoration(
hintText: '${round.firstNumber}',
),
),
flex: 3,
),
Spacer(
flex: 1,
),
Expanded(
child: TextFormField(
textAlign: TextAlign.center,
decoration: InputDecoration(
hintText: '${round.secondNumber}',
),
),
flex: 3,
),
],
),
)
),
);
}
}
【问题讨论】: