Flutter - значение DropdownButton остается пустым после выбора
Предположим, мы создали простую DropdownButton ABCPageState
в виджете с состоянием ABC.
class ABCPageState extends State<ABCPage> {
@override
Widget build(BuildContext context) {
return new Scaffold(
body: new Container(
child:
new DropdownButton(
hint: new Text("Please select value"),
items: <String>['Value 1', 'Value2'].map((String value) {
return new DropdownMenuItem<String>(
value: value,
child: new Text(value),
);
}).toList(),
onChanged: (_) {},
)
)
);
}
}
но НЕТ ЗНАЧЕНИЯ выбирается после того, как мы нажмем на один из вариантов. Другими словами - DropdownButton пуст, даже если мы нажали на элемент. Как мы можем это исправить?
1 ответ
Просто создать dropdownSelectedItem
переменная, которая будет хранить выбранный элемент. DropdownButton
имеет value
свойство, которое устанавливает выбранное значение. в onChanged
обратный вызов - установите значение dropdownSelectedItem
переменная. Не забудьте позвонить setState
метод впоследствии, чтобы перерисовать пользовательский интерфейс.
class ABCPageState extends State<ABCPage> {
var dropdownSelectedItem;
@override
Widget build(BuildContext context) {
return new Scaffold(
body: new Container(
child:
new DropdownButton(
hint: new Text("Please select value"),
items: <String>['Value 1', 'Value2'].map((String value) {
return new DropdownMenuItem<String>(
value: value,
child: new Text(value),
);
}).toList(),
value: dropdownSelectedItem,
onChanged: (val) { dropdownSelectedItem = val; setState((){}); },
),
),
);
}
}