更改数据源时,C#DataGridView未更新

ede*_*iss 16 c# winforms

我有一个对象列表

List<MobilePhone> results;
Run Code Online (Sandbox Code Playgroud)

所以我将列表添加到datagridview

dataGridView.DataSource = phase3Results;
Run Code Online (Sandbox Code Playgroud)

所以我有一些下拉框,在下拉框中选中任何项目的更改时决定列表结果,所以我的列表结果发生了变化,但是在datagridview上没有反映出来.有没有办法"刷新"变化?

Sae*_*ini 36

快速而肮脏的解决方案:

dataGridView.DataSource = null;
dataGridView.DataSource = phase3Results;
Run Code Online (Sandbox Code Playgroud)

清洁正确的解决方案:

使用BindingList<T>而不是List<T>作为您的数据源.List<T>当集合发生变化时不会触发事件.

另外,如果您还实现INotifyPropertyChangedT,BindingList<T>自动订阅每个属性更改T集合中,并且让视图知道的变化.

  • 目标不是因为结果集已更改而重新填充网格吗? (2认同)

Chr*_*ler 13

尝试使用BindingList <>而不是List <>和(如Daniel已经建议的那样),实现INotifyPropertyChanged.但是,如果您不想实现INotifyPropertyChanged接口,我认为您也可以调用.Refesh().

这是一个从这里撕掉的例子

public class Car : INotifyPropertyChanged
 {
   private string _make;
   private string _model;
   private int _year;

  public event PropertyChangedEventHandler PropertyChanged;

  public Car(string make, string model, int year)
   {
     _make = make;
     _model = model;
     _year = year;
   }

  public string Make
   {
     get { return _make; }
     set
     {
       _make = value;
       this.NotifyPropertyChanged("Make");
     }
   }

  public string Model
   {
     get { return _model; }
     set
     {
       _model = value;
       this.NotifyPropertyChanged("Model");
     }
   }

  public int Year
   {
     get { return _year; }
     set
     {
       _year = value;
       this.NotifyPropertyChanged("Year");
     }
   }

  private void NotifyPropertyChanged(string name)
   {
     if(PropertyChanged != null)
       PropertyChanged(this, new PropertyChangedEventArgs(name));
   }
 }

_dgCars.AutoGenerateColumns = false;

DataGridViewTextBoxColumn makeColumn = new DataGridViewTextBoxColumn();
 makeColumn.DataPropertyName = "Make";
 makeColumn.HeaderText = "The Car's Make";

DataGridViewTextBoxColumn modelColumn = new DataGridViewTextBoxColumn();
 modelColumn.DataPropertyName = "Model";
 modelColumn.HeaderText = "The Car's Model";

DataGridViewTextBoxColumn yearColumn = new DataGridViewTextBoxColumn();
 yearColumn.DataPropertyName = "Year";
 yearColumn.HeaderText = "The Car's Year";

_dgCars.Columns.Add(makeColumn);
 _dgCars.Columns.Add(modelColumn);
 _dgCars.Columns.Add(yearColumn);

BindingList<Car> cars = new BindingList<Car>();

cars.Add(new Car("Ford", "Mustang", 1967));
 cars.Add(new Car("Shelby AC", "Cobra", 1965));
 cars.Add(new Car("Chevrolet", "Corvette Sting Ray", 1965));

_dgCars.DataSource = cars;
Run Code Online (Sandbox Code Playgroud)