我有一个包含数据网格的WPF应用程序。我有一个名为OrderBlock的对象,它包含一个名为Orders的列表。此列表绑定到我的datagrid。
我遇到的问题是用户导入的订单列表会被读入我的“订单”列表中。这很好用& datagrid显示所有订单(总共说10个订单)。然后用户单击按钮发送订单。该应用程序然后从外部应用程序等待,看看是否有任何订单有问题。
假设一个订单有问题,但其他9个订单已从我的列表中删除。我的数据网格仍显示所有10个订单? OrderBlock除了列表之外还有其他属性在我的UI上更新,不明白为什么列表不是?
如果我单步执行我的代码并在我的列表的setter中停止“OnPropertyChanged”,它确实有效。
另外要指出的是,有一个问题的订单有一个名为RejectReason的属性,它确实从null变为“Some Error”。 Confussed。
修改 - 添加了代码
OrderBlock对象中的两个属性 - OrderCountSuccess确实更新列表,除非调试。
public int OrdersCountSuccess
{
get { return _ordersCountSuccess; }
set { _ordersCountSuccess = value; OnPropertyChanged("OrdersCountSuccess"); }
}
public List<Order> Orders
{
get { return _orders; }
set { _orders = value; OnPropertyChanged("Orders"); }
}
包含订单列表的OrderBlock对象(在我的视图模型中)
public OrderBlock OrderBlockEntity
{
get
{
return _orderBlockEntity;
}
set
{
_orderBlockEntity = value;
OnPropertyChanged("OrderBlockEntity");
}
}
此方法是将订单读入我的列表,然后成功显示在我的datagird
中 private void ImportRun()
{
OrderBlockEntity = Qoe.GetOrders(_fileLocation);
}
此方法是订单返回时的任何错误信息&amp;数据网格没有更新,虽然我可以看到列表已更改
private void SendRun()
{
OrderBlockEntity = Qoe.SendOrders(OrderBlockEntity);
}
的Xaml
<!-- Grid that contains the DataGrid which shows the list of orders -->
<Grid Grid.Row="2" x:Name="GridOrders">
<!-- The data grid to display orders-->
<DataGrid DataContext="{Binding OrderBlockEntity}"
x:Name="dataGridOrders"
ItemsSource="{Binding Orders}"
Style="{StaticResource DataGridTemplate}"
ColumnHeaderStyle="{StaticResource DG_ColumnHeader}"
RowStyle="{StaticResource DG_Row}"
CellStyle="{StaticResource DG_Cell}"
RowDetailsTemplate="{StaticResource DG_RowDetail}"
RowHeaderStyle="{StaticResource DG_RowHeader}"
AutoGenerateColumns="False"
HorizontalAlignment="Stretch"
VerticalAlignment="Stretch"
Background="Silver"
RowHeaderWidth="30"
Margin="25,5,20,15"
RowDetailsVisibilityChanged="dataGridOrders_RowDetailsVisibilityChanged">
<DataGrid.RowHeaderTemplate>
<DataTemplate>
<ToggleButton x:Name="RowHeaderToggleButton"
Click="RowHeaderToggleButton_Click"
Cursor="Hand"/>
<DataTemplate.Triggers>
<DataTrigger Binding="{Binding DataContext.MultiID, RelativeSource={RelativeSource Mode=FindAncestor, AncestorType={x:Type DataGridRow}}}" Value="False">
<Setter TargetName="RowHeaderToggleButton" Property="Visibility" Value="Collapsed"/>
</DataTrigger>
</DataTemplate.Triggers>
</DataTemplate>
</DataGrid.RowHeaderTemplate>
<DataGrid.Columns>
<DataGridComboBoxColumn Header="Action">
<DataGridComboBoxColumn.ElementStyle>
<Style TargetType="ComboBox">
<Setter Property="ItemsSource" Value="{Binding RelativeSource={RelativeSource FindAncestor, AncestorType={x:Type DataGrid}}, Path=DataContext.StatusList}"/>
<Setter Property="IsReadOnly" Value="True"/>
<Setter Property="SelectedValue" Value="{Binding StatusGood}"/>
<Setter Property="Background" Value="Silver"/>
</Style>
</DataGridComboBoxColumn.ElementStyle>
<DataGridComboBoxColumn.EditingElementStyle>
<Style TargetType="ComboBox">
<Setter Property="ItemsSource" Value="{Binding RelativeSource={RelativeSource FindAncestor, AncestorType={x:Type DataGrid}}, Path=DataContext.StatusList}"/>
<Setter Property="IsReadOnly" Value="True"/>
<Setter Property="SelectedValue" Value="{Binding StatusGood, UpdateSourceTrigger=PropertyChanged}"/>
<Setter Property="Background" Value="Silver"/>
</Style>
</DataGridComboBoxColumn.EditingElementStyle>
</DataGridComboBoxColumn>
<DataGridTextColumn Header="Fund" Binding="{Binding Account}" IsReadOnly="True"/>
<DataGridTextColumn Header="Security ID" Binding="{Binding Security.ID}" IsReadOnly="True"/>
<DataGridTextColumn Header="ThinkFolio Security ID" Binding="{Binding Security.IDThinkFolio}" IsReadOnly="True"/>
<DataGridTextColumn Header="Security Name" Binding="{Binding Security.Name}" IsReadOnly="True"/>
<DataGridTextColumn Header="Buy/Sell" Binding="{Binding TransType}" IsReadOnly="True"/>
<DataGridTextColumn Header="Quantity" Binding="{Binding OrderQunatity, StringFormat=\{0:N0\}}" IsReadOnly="False"/>
<DataGridTextColumn Header="Currency" Binding="{Binding Security.Currency}" IsReadOnly="False"/>
<DataGridTextColumn Header="Manager" Binding="{Binding FundManager}" IsReadOnly="True"/>
<DataGridTextColumn Header="Dealing Desk" Binding="{Binding Dealer}" IsReadOnly="False"/>
<DataGridTextColumn Header="Order Reason" Binding="{Binding OrderReason}" IsReadOnly="False"/>
<DataGridTextColumn Binding="{Binding RejectReason}" IsReadOnly="True">
<DataGridTextColumn.Header>
<TextBlock Text="{Binding DataContext.ColumnHeadInfo, RelativeSource={RelativeSource AncestorType={x:Type local:MainWindow}}}"/>
</DataGridTextColumn.Header>
</DataGridTextColumn>
<DataGridTextColumn Header="Comments" Binding="{Binding Comments}" IsReadOnly="False" Width="*"/>
</DataGrid.Columns>
</DataGrid>
</Grid>
答案 0 :(得分:2)
使用ObservableCollection而不是List。
答案 1 :(得分:0)
setter中的PropertyChanged事件起作用的原因是它重新设置了整个ItemsSource, 所以这是你可以解决这个问题的一种方法,更有效的方法是使用ObservableCollection, 您的ItemsControl侦听 INotifyCollectionChanged.CollectionChanged 事件,并更新ItemsContainerGenerator,它负责每个项目的实际UI元素。