2014-01-07 114 views
0

我有一个包含一个DataGrid WPF应用程序。我有一个名为OrderBlock的对象,其中包含一个名为Orders的列表。这个列表绑定到我的数据网格。WPF Datagrid的结合问题

我的问题是一个用户导入其读入我的名单“订单”订单列表。这工作正常& datagrid显示所有的订单(让我们说总共10个订单)。用户然后点击一个按钮发送订单。然后应用程序从外部应用程序等待,看看是否有任何订单有问题。

比方说,一个为了有一个问题,但其他9个已经从我的名单中删除。我的数据网格仍然显示所有10个订单?除了在我的用户界面上更新的列表以外,OrderBlock还有其他属性,不明白为什么列表不是。

如果我逐句通过我的代码,并停止在我的名单的制定者,它的工作“OnPropertyChanged”。其他

有一点需要指出的是,这有一个问题一个订单有一个名为RejectReason属性,它确实从零到“一些错误”的变化。 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); 
} 

这种方法是在命令回来跟任何错误信息& DataGrid中没有更新,虽然我可以看到列表已经改变

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

据我所见,你的OrderBlock不会触发,因为它没有实现INotifyCollectionChanged - 因为OrderBlock是你的Orders集合,它应该实现这个。尽管如此,我认为你可以用ObservableCollection更好,请查看@ user1729313答案! :) – Eisenhorn

回答

2

使用的ObservableCollection,而不是名单。

+0

...并且不要忘记实施INotifyCollectionChanged – Eisenhorn

+0

@Eisenhorn他应该在哪里实现INotifyCollectionChanged? ObservableCollection实现INotifyCollectionChanged。 –

+0

@eranotzap:当然,你是对的。但是集合中的项目必须实现INotifyPropertyChanged。 – Eisenhorn

0

之所以在二传手PropertyChanged事件的工作原理是,因为它重新设置整个的ItemsSource, 所以这是你可以接近这个问题的一种方式,更有效的方法是使用一个ObservableCollection, 你的ItemsControl听INotifyCollectionChanged.CollectionChanged事件并更新负责每个项目的实际UI元素的ItemsContainerGenerator。