首页 > 解决方案 > 如何在颤动中将初始值设置为下拉菜单?

问题描述

如何在颤动中将初始值设置为下拉菜单?

在下拉菜单中我想设置初始值,目前它的显示提示值“选择语言”。我需要在那里显示初始值。就像我的初始值是英语一样,那应该是我的下拉菜单中的选定项。

下面是我的代码:

new DropdownButtonHideUnderline(

               child: new DropdownButton<Language>(
                 hint: new Text("Select Language"),
                 value: selectedLanguage,
                 onChanged: (Language newValue) {
                   applic.onLocaleChanged(new Locale(newValue.languageCode,''));
                   setState(() {
                     selectedLanguage = newValue;
                   });
                 },
                 items: listLanguage.map((Language language) {
                   return new DropdownMenuItem<Language>(
                     value: language,
                     child: new Text(

                       language.languageName ,
                       style: new TextStyle(color: Colors.black),
                     ),
                   );
                 }).toList(),
               ),
             )

我的列表初始化为:

List<Language> listLanguage =
  <Language> [new Language("English", "en"),
  new Language("French", "fr"),
  new Language("Hindi", "hi"),

  ];

 Language selectedLanguage;

在此处输入图像描述

标签: dartflutterflutter-layout

解决方案


为了使下拉列表能够识别哪些语言是相同的,您需要实现operator==and hashCode

class Language {
  final String code;
  final String name;

  const Language(this.name, this.code);

  int get hashCode => code.hashCode;

  bool operator==(Object other) => other is Language && other.code == code;
}

至少如果你不使用constlike

const Language("English", "en"),

或重用以前创建的实例

selectedLanguage = listLanguage[0];

因为没有operator==const

selectedLanguage = new Language("English", "en");

将指向一个完全不同的Language实例,因为listLanguage下拉列表现在知道它们应该被识别为相同的。


推荐阅读