我有定义我的itemsource的当前代码(我要向用户显示的内容):
public class View
{
public string Name { get; set; }
public string Quantity { get; set; }
public List<Item> items { get; set; }
}
public class Item
{
public string ItemName { get; set; }
public double ItemQuantity { get; set; }
}
使用DataSet:
List<View> myViews
所以你最终得到的数据如下:
ViewA 50 {ItemA 50, ItemB 10, ItemC 20)
ViewB 10 {ItemC 10, ItemD 10, ItemE 10)
在我的datagrid中,它现在完美地显示了前两列,但List显示为“Collection”(不是实际数据),我猜这是预期的。
这是我现在的XAML
<DataGrid Grid.Row="2" Margin="0,146,0,350"
ItemsSource="{Binding myViews}"
AutoGenerateColumns="False" Height="104">
<DataGrid.Columns>
<DataGridTextColumn Header="Name" Width="*" FontSize="16"
Binding="{Binding Path=Name}" />
<DataGridTextColumn Header="Quantity" Width="*" FontSize="16"
Binding="{Binding Path=Quantity}" />
<DataGridTextColumn Header="Items" Width="*" FontSize="16"
Binding="{Binding Path=items}" />
</DataGrid.Columns>
</DataGrid>
我正在尝试找到一种方法来向用户表示List项(无论是在这个数据网格中还是其他方式,如果这不是正确的方法)。
我的想法是在第3列中实际拥有另一个具有自己的项目源的Datagrid,但我似乎无法找到如何使第3列成为Datagrid(而不是像今天这样的文本) 。有谁知道如何做到这一点(一些例子会很棒)。
或者,如果这不是解决此问题的正确方法,那么任何其他想法也将非常受欢迎。
谢谢,
答案 0 :(得分:1)
您可以使用RowDetailsTemplate
来显示Item对象列表。
<DataGrid Grid.Row="2" Margin="0,146,0,350"
ItemsSource="{Binding myViews}"
AutoGenerateColumns="False" Height="104">
<DataGrid.RowDetailsTemplate>
<DataTemplate>
<DataGrid AutoGenerateColumns="False" ItemsSource="{Binding items}">
<DataGrid.Columns>
<DataGridTextColumn Header="Item Name" Width="Auto" FontSize="16"
Binding="{Binding Path=ItemName}" />
<DataGridTextColumn Header="Item Quantity " Width="Auto" FontSize="16"
Binding="{Binding Path=ItemQuantity }" />
</DataGrid.Columns>
</DataGrid>
</DataTemplate>
</DataGrid.RowDetailsTemplate>
<DataGrid.Columns>
<DataGridTextColumn Header="Name" Width="*" FontSize="16"
Binding="{Binding Path=Name}" />
<DataGridTextColumn Header="Quantity" Width="*" FontSize="16"
Binding="{Binding Path=Quantity}" />
</DataGrid.Columns>
</DataGrid>
如果您想在第三列中显示Item对象的列表,则应使用DataGridTemplateColumn
。
<DataGrid Grid.Row="2" Margin="0,146,0,350"
ItemsSource="{Binding myViews}"
AutoGenerateColumns="False" Height="104">
<DataGrid.Columns>
<DataGridTextColumn Header="Name" Width="*" FontSize="16"
Binding="{Binding Path=Name}" />
<DataGridTextColumn Header="Quantity" Width="*" FontSize="16"
Binding="{Binding Path=Quantity}" />
<DataGridTemplateColumn Header="Items">
<DataGridTemplateColumn.CellTemplate>
<DataTemplate>
<DataGrid AutoGenerateColumns="False" ItemsSource="{Binding items}">
<DataGrid.Columns>
<DataGridTextColumn Header="Item Name" Width="Auto" FontSize="16"
Binding="{Binding Path=ItemName}" />
<DataGridTextColumn Header="Item Quantity " Width="Auto" FontSize="16"
Binding="{Binding Path=ItemQuantity }" />
</DataGrid.Columns>
</DataGrid>
</DataTemplate>
</DataGridTemplateColumn.CellTemplate>
</DataGridTemplateColumn>
</DataGrid.Columns>
</DataGrid>