MVVM 更新组合框项源和刷新

本文关键字:刷新 更新 组合 MVVM | 更新日期: 2023-09-27 18:36:44

我正在处理一个WPF项目及其MVVM。我在刷新组合框绑定值时遇到问题。所以,在这种情况下,我的网格上有一个组合框和按钮。我需要更改数据源,然后刷新以查看根据之前选择的步骤的新值。

请告诉我喜欢下一个按钮的最佳方法是什么?之后可能需要喜欢上一个按钮。

public MyScriptForm(IMyScriptModel viewModel) {
  this.Model=viewModel;
  InitializeComponent();
  Height=Double.NaN;
  Width=Double.NaN;
}
public IMyScriptModel Model {
  get {
    return this.DataContext as IMyScriptModel;
  }
  set {
    this.DataContext=value;
  }
}
private void btnNext_Click(object sender,
RoutedEventArgs e) {
  /// to what ?
  Model.cbxAnswer.Clear();
  Model.cbxAnswer.add("Step2Data");
}
Create{//its a huge project, this working on when this form created
  myScript.Model.cbxAnswer.Add("1");
  myScript.Model.cbxAnswer.Add("2");
  myScript.Model.cbxAnswer.Add("3");
  }
destroy{}
////////////////////////
//Onmy model 
public List<string> cbxAnswer {
  get {
    return m_cbxAnswer;
  }
  set {
    m_cbxAnswer=value;
    OnPropertyChanged("cbxAnswer");
  }
}
public List<string> m_cbxAnswer=new List<string>();
 public event PropertyChangedEventHandler PropertyChanged;
 protected void OnPropertyChanged(string propertyName) {
  if (PropertyChanged !=null) PropertyChanged(this, new PropertyChangedEventArgs(propertyName));
}

XAML:

<Grid>
  <ComboBox Name="cbxAnswer" HorizontalAlignment="Left" Margin="10,130,0,0" VerticalAlignment="Top" Width="130" Height="25" ItemsSource="{Binding Path=cbxAnswer}" />
  <Button Name="btnNext" HorizontalAlignment="Left" Margin="215,130,0,0" VerticalAlignment="Top" Width="75" Content="İlerle" Click="btnNext_Click" />
</Grid>

MVVM 更新组合框项源和刷新

您只是在集合中添加和删除(而不是创建一个新集合)。这意味着您需要一个实现 INotifyCollectionChanged 的集合。

已经这样做的一个非常方便的类是 ObservableCollection<T> ,我将使用它而不是在这里List<T>,以及您需要集合更改才能传播到 UI 的其他任何地方。

如果确实要执行完全刷新,则可以考虑仅重新创建集合,而不是执行添加/删除。这可以为您带来净性能提升,因为单独执行每个操作必须由 UI 处理,而不是一次处理所有操作。