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>
您只是在集合中添加和删除(而不是创建一个新集合)。这意味着您需要一个实现 INotifyCollectionChanged
的集合。
已经这样做的一个非常方便的类是 ObservableCollection<T>
,我将使用它而不是在这里List<T>
,以及您需要集合更改才能传播到 UI 的其他任何地方。
如果确实要执行完全刷新,则可以考虑仅重新创建集合,而不是执行添加/删除。这可以为您带来净性能提升,因为单独执行每个操作必须由 UI 处理,而不是一次处理所有操作。