将DataGrid绑定到另一个DataGrid中的行

时间:2013-10-01 17:17:08

标签: c# wpf mvvm binding datagrid

我有一个班级Book

class Book
{
 public int Id {get; set;}
 public string Title {get; set;}
 public string Authors {get; set;}
 public string Genre {get; set;}
 public virtual ICollection <Publication> Publications {get; set;}
}

在表单上有两个(让AB)DataGrids:A显示Book个对象的列表,B显示所选书籍的Publications中的元素(即绑定到A中的选定行)。

问题是如何将B绑定到A中的当前行?

我这样做,但在我看来,这不太正确:

<DataGrid x:Name="BooksGrid"
          ItemsSource="{Binding Path=WorkingBooksSet, Mode=TwoWay}"
          IsSynchronizedWithCurrentItem="True" RowDetailsVisibilityMode="VisibleWhenSelected"
          AutoGenerateColumns="False">
  <DataGrid.Columns>
    <DataGridTextColumn Binding="{Binding Path=Id}" Width="Auto" />
    <DataGridTextColumn Binding="{Binding Path=Title}" Width="*" />
    <DataGridTextColumn Binding="{Binding Path=Authors}" Width="*" />
    <DataGridTextColumn Binding="{Binding Path=Genre}" Width="*" />
  </DataGrid.Columns>


  <DataGrid.RowDetailsTemplate>
    <DataTemplate>
      // Second DataGrid
      <DataGrid ItemsSource="{Binding ElementName=BooksGrid, Path=SelectedItem.Publications}"
                AutoGenerateColumns="False">
        <DataGrid.Columns>
          <DataGridTextColumn Binding="{Binding Path=Publisher}" />
          <DataGridTextColumn Binding="{Binding Path=ISBN}" />
          ...
        </DataGrid.Columns>
      </DataGrid>

    </DataTemplate>
  </DataGrid.RowDetailsTemplate>
</DataGrid>
我的ViewModel

中{p> WorkingBooksSetObservableCollection

所以我在this binding cheat sheet找到了解决方案。

1 个答案:

答案 0 :(得分:1)

我建议在ViewModel中使用SelectedBook属性并将DataGrid A的选定项绑定到它。

SelectedItem = "{Binding SelectedBook}"

然后,将DataGrid B的ItemsSource设置为publications属性。

ItemsSource="{Binding SelectedBook, Path=Publications}"