Как создать раскрывающийся список от поставщика? (Флаттер)

Я создал модель города и создал для этого класс провайдера,

class CityModel {
  String cityId;
  String cityName;

  CityModel({this.cityId, this.cityName});
}

Это класс провайдера

class CitiesProviders extends ChangeNotifier {
  List<CityModel> citiesData = [];

  void addData(CityModel data) {
    citiesData.add(data);
    notifyListeners();
  }

  List<String> get cityNames {
    List<String> names = [];
    citiesData.map((value) {
      names.add(value.cityName);
    });
    return names;
  }
}

Я просто хочу получить названия городов из списка citiesData и использовать этот список для создания раскрывающегося списка.

DropdownButton<String>(
      value: currVal,
      items: Provider.of<CitiesProviders>(context)
          .cityNames
          .map<DropdownMenuItem<String>>((String value) {
        return DropdownMenuItem<String>(
          value: value,
          child: Text(value),
        );
      }).toList(),
      onChanged: (value) {
        currVal = value;
      },
    ),

Но у меня ничего не появляется на экране, также нет сообщения об ошибке. Я все делаю правильно? Или есть способ лучше? Любые предложения и ответы помогут. Спасибо!


person Sanchit Rastogi    schedule 02.03.2020    source источник


Ответы (2)


Я считаю, что проблема в том, что у вас есть:

class CitiesProviders extends ChangeNotifier {}

У тебя должно быть:

class CitiesProviders with ChangeNotifier {}

Я не вижу других проблем в остальной части вашего кода, но я все еще новичок во Flutter.

person TuMahler    schedule 03.03.2020

Виноват!

List<String> get cityNames {
    List<String> names = [];
    citiesData.map((value) {
      names.add(value.cityName);
    }).toList(); // Added here
    return name)s;
  }

Я добавил toList (), и теперь он работает.

person Sanchit Rastogi    schedule 03.03.2020