如何在ItemsControl数据模板中使用ComboBox SelectedItem



我正在编写一个向订单添加项目的表单。项目区域的XAML是这样的:

<ItemsControl Name="ServiceItems" ItemsSource="{Binding ServiceOrderItems}" Width="737" Canvas.Left="0" Canvas.Top="193" Visibility="{Binding ShowServiceItems, Converter={StaticResource BooleanToVisibility}}">
    <ItemsControl.ItemTemplate>
        <DataTemplate>
            <Grid>
                <Grid.RowDefinitions>
                    <RowDefinition Height="Auto"/>
                    <RowDefinition Height="Auto"/>
                </Grid.RowDefinitions>
                <Grid.ColumnDefinitions>
                    <ColumnDefinition Width="140*" />
                    <ColumnDefinition Width="320*" />
                    <ColumnDefinition Width="54*" />
                    <ColumnDefinition Width="35*" />
                    <ColumnDefinition Width="47*" />
                    <ColumnDefinition Width="47*" />
                    <ColumnDefinition Width="47*" />
                    <ColumnDefinition Width="47*" />
                </Grid.ColumnDefinitions>
                <ComboBox ItemsSource="{Binding ElementName=ServiceItems, Path=DataContext.ItemsList}" SelectedItem="{Binding Path=Item, Mode=TwoWay}" IsTextSearchEnabled="True">
                    <i:Interaction.Triggers>
                        <i:EventTrigger EventName="SelectionChanged">
                            <i:InvokeCommandAction Command="{Binding ElementName=ServiceItems, Path=DataContext.CommandAddServiceItem}"/>
                        </i:EventTrigger>
                    </i:Interaction.Triggers>
                </ComboBox>
                <TextBox Text="{Binding Description, Mode=TwoWay}" Grid.Column="1" />
                <TextBox Text="{Binding Available, Mode=TwoWay}" Grid.Column="2" />
                <TextBox Text="{Binding Quantity, Mode=TwoWay}" Grid.Column="3" />
                <TextBox Text="{Binding Rate, Mode=TwoWay}" Grid.Column="4" />
                <TextBox Text="{Binding Amount, Mode=TwoWay}" Grid.Column="5" />
                <CheckBox IsChecked="{Binding Taxable, Mode=TwoWay}" Grid.Column="6" />
                <CheckBox IsChecked="{Binding Closed, Mode=TwoWay}" Grid.Column="7" />
            </Grid>
        </DataTemplate>
    </ItemsControl.ItemTemplate>
    <ItemsControl.Template>
        <ControlTemplate TargetType="ItemsControl">
            <ScrollViewer CanContentScroll="True">
                <ItemsPresenter/>
            </ScrollViewer>
        </ControlTemplate>
    </ItemsControl.Template>
    <ItemsControl.ItemsPanel>
        <ItemsPanelTemplate>
            <VirtualizingStackPanel/>
        </ItemsPanelTemplate>
    </ItemsControl.ItemsPanel>
</ItemsControl>

这是我的MVVM类:

namespace ServiceOrders
{
    public class SalesOrderItem
    {
        public Int64 ItemId { get; set; }
        public string Item { get; set; }
        public string Description { get; set; }
        public int Available { get; set; }
        public double Quantity { get; set; }
        public double Rate { get; set; }
        public double Amount { get; set; }
        public bool Taxable { get; set; }
        public bool Closed { get; set; }
        public override string ToString()
        {
            return this.Item;
        }
    }
    public ObservableCollection<ServiceOrders.SalesOrderItem> ItemsList { get; set; }
    public ObservableCollection<ServiceOrders.SalesOrderItem> ServiceOrderItems { get; set; }
    public SalesOrderControlViewModel()
    {
        ItemsList = new ObservableCollection<ServiceOrders.SalesOrderItem>();
        ServiceOrderItems = new ObservableCollection<ServiceOrders.SalesOrderItem>();
    }
}

我所有的绑定似乎都可以工作,除了在ComboBox上。我想从项目列表(ItemsList)中拉,但随后我想将SelectedItem添加到ServiceOrderItems。当我选择项目时,它确实添加了它,但只添加了SalesOrderItem.Item,而不会添加描述,数量等。

我如何实现我想要做的事?我尝试了以下方法:

<ComboBox ItemsSource="{Binding ElementName=ServiceItems, Path=DataContext.ItemsList}" SelectedItem="{Binding ElementName=ServiceItems, Path=DataContext.SelectedServiceItem, Mode=TwoWay}" IsTextSearchEnabled="True" DisplayMemberPath="Item">

但是这只是将所有的项目行combobox设置为相同的东西。我也试过通过SelectionChanged事件这样做,然后试图获得SelectedItem并将其添加到ServiceOrderItems

我找遍了,就是找不到我想做的。

字符串被添加,因为您已经绑定了 SelectedItem 字符串值,我怀疑在您的命令中您添加了所选项目的命令。

<ComboBox ItemsSource="{Binding ElementName=ServiceItems,
                                Path=DataContext.ItemsList}"
          SelectedItem="{Binding Path=Item, Mode=TwoWay}">

将SelectedItem绑定到SalesOrderItem类型的对象上,说SelectedSalesOrderItem这样你就可以访问完整的对象。

你不需要重写ToString()如果它只是在comboBox中显示Item。您可以使用 DisplayMemberPath 属性来显示来自对象的UI上的特定属性。

<ComboBox ItemsSource="{Binding ElementName=ServiceItems,
                                Path=DataContext.ItemsList}"
          SelectedItem="{Binding Path=SelectedSalesOrderItem, Mode=TwoWay}"
          DisplayMemberPath="Item">

最新更新