0

我正在尝试使用可观察的集合和使用复合集合的标题行填充组合框。标题在那里,但我无法填充 OC 对象。我刚开始使用 OC,所以可能是我缺少的一些基本内容。

客户等级:

public class Customer : ViewModelBaseMain
{
    public string CustomerName { get; set; }
    public int CustomerId { get; set; }
}

我从数据表中填充了 OC,它是一个依赖属性(我验证了 OC 是否被正确填充):

ObservableCollection<Customer> dpCustomerListOC = new ObservableCollection<Customer>();
foreach (DataRow drow in dpHeaderCustTable.Rows)
{
    Customer Customer = new Customer();
    Customer.CustomerId = Convert.ToInt32(drow["customer_id"]);
    Customer.CustomerName = drow["customer_name"].ToString();
    dpCustomerListOC.Add(Customer);                            
}

在 usercontrol 资源中,我将 VM 指定为静态资源:

<local:ReservationViewModel x:Key="ReserveVM"/>

从我读过的帖子中,我尝试了两种不同的方式。

使用 x:reference 收集资源的第一种方式:

<ComboBox x:Name="cboCustHeader" Grid.IsSharedSizeScope="True" IsEditable="False"
          ItemsSource="{DynamicResource items}">                                  
     <ComboBox.Resources>
         <CompositeCollection x:Key="items">
              <ComboBoxItem IsEnabled="False">
                  <Border Style="{StaticResource ComboHeaderBorder}">
                     <Grid Style="{StaticResource ComboHeaderStyle}">
                         <Grid.ColumnDefinitions>
                             <ColumnDefinition SharedSizeGroup="A"/>
                             <ColumnDefinition Width="7"/>
                             <ColumnDefinition SharedSizeGroup="B"/>
                         </Grid.ColumnDefinitions>
                         <Grid.Children>
                            <TextBlock Grid.Column="0" Text="ID"/>
                            <TextBlock Grid.Column="2" Text="Name"/>
                         </Grid.Children>
                     </Grid>
                  </Border>
              </ComboBoxItem>
              <CollectionContainer Collection="{Binding Source={x:Reference cboCustHeader}, Path=DataContext.dpCustomerListOC}"/>
         </CompositeCollection>
     </ComboBox.Resources>                               
     <ComboBox.ItemTemplate>
          <DataTemplate>
              <Grid>
                  <Grid.ColumnDefinitions>
                      <ColumnDefinition SharedSizeGroup="A"/>
                      <ColumnDefinition Width="7"/>
                      <ColumnDefinition SharedSizeGroup="B"/>
                  </Grid.ColumnDefinitions>
                  <Grid.Children>
                     <TextBlock Text="{Binding Path=CustomerId, Mode=TwoWay, UpdateSourceTrigger=PropertyChanged}"/>
                     <TextBlock Text="{Binding Path=CustomerName, Mode=TwoWay, UpdateSourceTrigger=PropertyChanged}"/>
                  </Grid.Children>
              </Grid>
          </DataTemplate>
     </ComboBox.ItemTemplate>
</ComboBox>

指定来源的第二种方式:

<ComboBox x:Name="cboCustHeader" Grid.IsSharedSizeScope="True">
    <ComboBox.ItemsSource>
        <CompositeCollection>
            <ComboBoxItem IsEnabled="False">
               <Border Style="{StaticResource ComboHeaderBorder}">
                   <Grid Style="{StaticResource ComboHeaderStyle}">
                       <Grid.ColumnDefinitions>
                           <ColumnDefinition SharedSizeGroup="A"/>
                           <ColumnDefinition Width="7"/>
                           <ColumnDefinition SharedSizeGroup="B"/>
                       </Grid.ColumnDefinitions>
                       <Grid.Children>
                           <TextBlock Grid.Column="0" Text="ID"/>
                           <TextBlock Grid.Column="2" Text="Name"/>
                       </Grid.Children>
                   </Grid>
               </Border>
           </ComboBoxItem>
           <CollectionContainer Collection="{Binding Path=dpCustomerListOC, Source={StaticResource ReserveVM}}"/>                                                                      
      </CompositeCollection>
  </ComboBox.ItemsSource>
  <ComboBox.ItemTemplate>
      <DataTemplate>
          <Grid>
             <Grid.ColumnDefinitions>
                 <ColumnDefinition SharedSizeGroup="A"/>
                 <ColumnDefinition Width="7"/>
                 <ColumnDefinition SharedSizeGroup="B"/>
            </Grid.ColumnDefinitions>
            <Grid.Children>
                <TextBlock Grid.Column="0" Text="{Binding Path=CustomerId, Mode=TwoWay, UpdateSourceTrigger=PropertyChanged}"/>
                <TextBlock Grid.Column="2" Text="{Binding Path=CustomerName, Mode=TwoWay, UpdateSourceTrigger=PropertyChanged}"/>
            </Grid.Children>
          </Grid>
      </DataTemplate>
  </ComboBox.ItemTemplate>                        

4

2 回答 2

0

添加一个公共属性,在您的视图模型上公开该集合:

public ObservableCollection<Customer> DpCustomerListOC 
{ 
    get { return dpCustomerListOC; }
}

并将组合绑定ItemsSource到它:

    <ComboBox x:Name="cboCustHeader" Grid.IsSharedSizeScope="True">
        <ComboBox.ItemsSource>
            <CompositeCollection>
                <ComboBoxItem IsEnabled="False">
                    <Border Style="{StaticResource ComboHeaderBorder}">
                        <Grid Style="{StaticResource ComboHeaderStyle}">
                            <Grid.ColumnDefinitions>
                                <ColumnDefinition SharedSizeGroup="A"/>
                                <ColumnDefinition Width="7"/>
                                <ColumnDefinition SharedSizeGroup="B"/>
                            </Grid.ColumnDefinitions>
                            <Grid.Children>
                                <TextBlock Grid.Column="0" Text="ID"/>
                                <TextBlock Grid.Column="2" Text="Name"/>
                            </Grid.Children>
                        </Grid>
                    </Border>
                </ComboBoxItem>
                <CollectionContainer Collection="{Binding Path=DpCustomerListOC, Source={StaticResource ReserveVM}}"/>
            </CompositeCollection>
        </ComboBox.ItemsSource>
        <ComboBox.ItemTemplate>
            <DataTemplate>
                <Grid>
                    <Grid.ColumnDefinitions>
                        <ColumnDefinition SharedSizeGroup="A"/>
                        <ColumnDefinition Width="7"/>
                        <ColumnDefinition SharedSizeGroup="B"/>
                    </Grid.ColumnDefinitions>
                    <Grid.Children>
                        <TextBlock Grid.Column="0" Text="{Binding Path=CustomerId, Mode=TwoWay, UpdateSourceTrigger=PropertyChanged}"/>
                        <TextBlock Grid.Column="2" Text="{Binding Path=CustomerName, Mode=TwoWay, UpdateSourceTrigger=PropertyChanged}"/>
                    </Grid.Children>
                </Grid>
            </DataTemplate>
        </ComboBox.ItemTemplate>
    </ComboBox>

确保在构造函数中填充集合。

于 2014-07-17T14:59:48.443 回答
0

似乎您缺少 NotifyPropertyChange。在使用 ComboBoxs 时,我通常只做这样的事情:

<ComboBox ItemsSource="{Binding Customers, Mode=OneWay}"
          SelectedItem="{Binding SelectedCustomer, Mode=TwoWay}"> </ComboBox>

然后在你的课上:

public type Customers
{
    get{return _Customers} 
    set{_SelectedCustomer = value; 
        NotifyPropertyChanged("Customers");}
}

public type SelectedCustomer
{
    get{return _SelectedCustomer;} 
    set{_SelectedCustomer = value;
        NotifyPropertyChanged("SelectedCustomer")}
}

语法可能有点偏离,但类似这样的东西应该填充 ComboBox。

于 2014-07-17T14:52:35.903 回答