0

我要添加的对象DropDownButton

class Car {
  int id;
  String make;

  Car(this.id, this.make);

  static List<Car> getCars() {
    var cars = new List<Car>();
    cars.add(Car(1, "Ford"));
    cars.add(Car(2, "Toyota"));
    cars.add(Car(3, "BMW"));

    return cars;
  }
}

构造 DropDown(StatefulWidget 状态类):

class _MyHomePageState extends State<MyHomePage> {
  Car _selectedCar;

  @override
  Widget build(BuildContext context) {
    return Scaffold(
        appBar: AppBar(
          title: Text(widget.title),
        ),
        body: Center(child: getDropDown()));
  }

  Widget getDropDown() {
    var cars = Car.getCars();
    this._selectedCar = cars.first; // Default to first value in list.
    var items = cars.map((car) {
      return new DropdownMenuItem<Car>(
        value: car,
        child: new Text(car.make),
      );
    }).toList();

    return DropdownButton<Car>(
        value: this._selectedCar,
        onChanged: (Car car) {
          setState(() {
            this._selectedCar = car;
          });
        },
        items: items);
  }
}

DropDownButton选择第一个项目时正确显示,但是当我选择另一个项目时,UI 永远不会更新以显示新项目为选中状态。

4

2 回答 2

2

您只需初始化一次列表,因为如果您在每次绘制时都初始化新列表,则 DropDownList 值不会匹配。

在这里找到的工作示例:Gist

于 2019-03-27T11:47:13.680 回答
0

尝试在您的方法而不是方法中初始化_selectedCar变量。initState()getDropdown()

根据您发布的代码,_selectedCar每次调用时都会重新初始化变量,setState()因为调用了build()方法。

您还提到在第一个答案中尝试解决方案时遇到以下错误:

I/flutter(5072):'package:flutter/src/material/dropdown.dart':断言失败:第 560 行 pos 15:'items == null || 我/颤振(5072):items.isEmpty || 值 == 空 || items.where((DropdownMenuItem item) => item.value == I/flutter (5072): value).length == 1': 不正确。

这很可能是因为下拉列表中的多个项目获得了相同的值。

一个可能的解决方法是使用对象的id参数Car作为下拉列表value而不是整个对象,因为id每个对象都是唯一的。可以在此处找到有关此错误的更多详细信息。

于 2019-03-27T12:25:09.600 回答