Flutter - значение по умолчанию в раскрывающемся списке

Я пытаюсь отправить элемент в одно представление. Этот элемент будет элементом по умолчанию в раскрывающемся списке второй страницы. Я использую что-то подобное на первой странице

  onTap: () {
                        Navigator.push(
                            context,
                            new MaterialPageRoute(
                                builder: (context) => new SummaryPage(,
                                    dropdownItem: dropdownSelection)));
                      } 

Затем на второй странице я создаю будущее, чтобы получить все элементы в раскрывающемся списке, и метод initstate, чтобы установить раскрывающийся список элементов по умолчанию.

 List data = List();

 Future<Null> getEstates() async {
    final response = await http
        .get('URL'
    }).catchError((error) {
      print(error.toString());
    });
    final responseJson = json.decode(response.body);
    final getBody = responseJson['body'];
    setState(() {
      data = getBody;
      loading = false;
    });
  }


 void initState() {
    super.initState();     

     setState(() {
          dropdownSelection = widget.dropdownItem.toString();
        });

getEstate вернуть это

[{id: 1, descripcion: Terreno Rio}, {id: 2, descripcion: Terreno Asier}]

Выпадающий список выглядит примерно так

child: ButtonTheme(
                    alignedDropdown: true,
                    child: new DropdownButton<String>(
                      isDense: true,
                      hint: new Text("Search...",
                          textAlign: TextAlign.center),
                      value: dropdownSelection,
                      onChanged: (String newValue) {
                        setState(() {
                          dropdownSelection = newValue;
                      },
                      items: data.map((item) {
                        return new DropdownMenuItem<String>(
                          child: new Text(
                            item['description'],
                          ),
                          value: item['id'].toString(),
                        );
                      }).toList(),
                    ),
                  ),

Отображаемая ошибка

value == null || items.where((DropdownMenuItem item) => item.value == value).length == 1': is not true

По-видимому, код в порядке, но когда я перехожу ко второму представлению, отображается сообщение об ошибке около 1 секунды, а затем отображается вторая страница. Я думаю, что значение может быть загружено слишком рано, и раскрывающийся список не может быть настроен должным образом. Есть идеи, почему возникает эта ошибка и как ее исправить?

5
0
13 308
2
Перейти к ответу Данный вопрос помечен как решенный

Ответы 2

Могут быть две ошибки, которые я могу придумать с помощью вашего кода:

  1. значение элемента DropdownMenutItem не уникально, т.е. некоторые идентификаторы повторяются.
  2. идентификатор, который вы передаете PageTwo, не соответствует ни одному из идентификаторов в меню.

Я бы предложил использовать только int id вместо String в качестве значения

Я не могу найти эту ошибку. Если я передаю dropdownSelection = "1": items.where ((DropdownMenuItem <T> item) => item.value == value) .length == 1 ': неверно.

El Hombre Sin Nombre 03.12.2018 14:09
Ответ принят как подходящий

Это потому, что в первый раз у вас нет никакого значения (ваш список пуст), поэтому вы можете отобразить CircleProgressIndicator, например:

        child: data.length > 0 ? ButtonTheme(
                        alignedDropdown: true,
                        child: new DropdownButton<String>(
                          isDense: true,
                          hint: new Text("Buscar..",
                              textAlign: TextAlign.center),
                          value: dropdownSelection,
                          onChanged: (String newValue) {
                            setState(() {
                              dropdownSelection = newValue;              
                          },
                          items: data.map((item) {
                            return new DropdownMenuItem<String>(
                              child: new Text(
                                'Finca: ' + item['descripcion'],
                              ),
                              value: item['id'].toString(),
                            );
                          }).toList(),
                        ),
                      ),
                    ) : Center(child: CircularProgressIndicator()),

Другие вопросы по теме