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((){}); },
            ),
      ), 
    );
  }
}
Другие вопросы по тегам