我有以下课程:
public class Order
{
public string OrderName { get; set; }
public List<Parts> PartsList { get; set; }
}
public class Parts
{
public string PartName { get; set; }
public double PartQuantity { get; set; }
}
在我的代码中,我创建了一个 Order 对象列表
List<Order> myOrders;
我想以某种方式向用户显示所有这些,比如使用元素的堆栈面板,其中第一个是 TextBox 来显示 OrderName,第二个是 Datagrid 来显示部件列表?
老实说,我正在尝试许多不同的事情(我对使用什么类型的控件没有要求),但我永远无法正确显示 PartsList(要么我什么也没得到,要么我得到“收藏”显示给用户。
我们的目标是看到这样的东西:
Order1 Part1 7
Part2 12
Order2 Part1 100
Part2 1
Part3 58
这是我今天拥有的 XAML,我真的认为它会起作用:
<ItemsControl x:Name="visual"
ItemsSource="{Binding myOrders}"
HorizontalAlignment="Stretch"
HorizontalContentAlignment="Stretch"
Margin="0,397,37,31" Grid.Row="1" Height="172">
<ItemsControl.ItemTemplate>
<DataTemplate>
<ItemsControl ItemsSource="{Binding }"
HorizontalAlignment="Stretch"
HorizontalContentAlignment="Stretch">
<ItemsControl.ItemTemplate>
<DataTemplate>
<StackPanel>
<TextBlock Text="{Binding OrderName}"
Margin="10" />
<ItemsControl ItemsSource="{Binding PartsList}"
HorizontalAlignment="Stretch"
HorizontalContentAlignment="Stretch">
<ItemsControl.ItemTemplate>
<DataTemplate>
<Grid HorizontalAlignment="Stretch">
<Grid.ColumnDefinitions>
<ColumnDefinition Width="*" />
<ColumnDefinition Width="*" />
</Grid.ColumnDefinitions>
<TextBlock Grid.Column="0"
Text="{Binding PartName}"
TextAlignment="Center" />
<TextBlock Grid.Column="1"
Text="{Binding PartQuantity}"
TextAlignment="Center" />
</Grid>
</DataTemplate>
</ItemsControl.ItemTemplate>
</ItemsControl>
</StackPanel>
</DataTemplate>
</ItemsControl.ItemTemplate>
</ItemsControl>
</DataTemplate>
</ItemsControl.ItemTemplate>
</ItemsControl>
有谁看到这段代码有什么问题?