如何解决Flutter中下拉按钮的选择未更新
我创建了下拉按钮,但每当一个项被选择不更新value.But每当我hotreload所有我的值被更新。谁能猜出原因?还是有解决方案?
DropdownButton<String>(
value: dropdownValue,icon: Icon(Icons.keyboard_arrow_down),iconSize: 15,elevation: 10,style: TextStyle(color: Colors.grey),onChanged: (newValue) {
setState(() async {
dropdownValue = newValue;
final selectedLanguage= await SharedPreferences.getInstance();
selectedLanguage.setString('selectedLanguage',dropdownValue);
});
allTranslations.setNewLanguage(
allTranslations.getLocaleKey(
dropdownValue,),);
},items: <String>[
englishText,chineseText,russianText,].map<DropdownMenuItem<String>>((String value) {
return DropdownMenuItem<String>(
value: value,child: Text(value),);
}).toList(),
解决方法
@kimSoo太好了!
每个人的解决方案是setstate
中的异步关闭无法正常工作。我们必须将其删除并更早地初始化“共享首选项”。
更早地初始化final selectedLanguage= await SharedPreferences.getInstance();
DropdownButton<String>(
value: dropdownValue,icon: Icon(Icons.keyboard_arrow_down),iconSize: 15,elevation: 10,style: TextStyle(color: Colors.grey),onChanged: (newValue) {
setState(() { <----- removed async
dropdownValue = newValue;
selectedLanguage.setString('selectedLanguage',dropdownValue);
});
allTranslations.setNewLanguage(
allTranslations.getLocaleKey(
dropdownValue,),);
},items: <String>[
englishText,chineseText,russianText,].map<DropdownMenuItem<String>>((String value) {
return DropdownMenuItem<String>(
value: value,child: Text(value),);
}).toList(),
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。