DataGrid ComboBox绑定问题与选定或新项目

时间:2013-08-05 14:51:07

标签: wpf binding datagrid combobox

我遇到了在DataGridTemplate列ComboBox中保留所选项目的问题。 我将DataTemplate可编辑组合框列作为数据网格中的第一列,并在其旁边,我有一个文本列。 DataGrid填充了从SQL存储过程读取的数据。一切正常,除非我在组合框中选择一个项目并移动到文本字段并开始输入,组合选择就会消失。它会为新项目或现有项目清空。奇怪的是,这只是第一次发生。当我重新选择ComboBox值或再次添加新项目并返回到文本字段时,它不会消隐。我的想法用完了,尝试了许多组合,但到目前为止还没有运气。 这是我的代码:

这就是我填充DataGrid的方式:

using (SqlCommand cmd = new SqlCommand())
{
    cmd.CommandText = "GetProducts";
    cmd.CommandType = CommandType.StoredProcedure;
    cmd.Connection = sqlConn;

    var reader = cmd.ExecuteReader();
    var dt = new DataTable();
    dt.Load(reader);
    dt.Columns["ProductName"].AllowDBNull = true;
    dtProductCfgTable = dt;
    ProductCfgGrid.ItemsSource = dtProductCfgTable.DefaultView;
}

这是ProductNamesList的声明:

public List<string> ProductNamesList { get; set; }

XAML:

<DataGridTemplateColumn Header="ProductName">
   <DataGridTemplateColumn.CellTemplate>
      <DataTemplate>
        <ComboBox ItemsSource="{Binding ProductNamesList, 
                                RelativeSource={RelativeSource AncestorType=Window}}"  
                                SelectedItem="{Binding ProductName 
                                IsSynchronizedWithCurrentItem="False"  
                                BorderThickness="1.2 1.2 0 0" BorderBrush="Black" 
                                Background="LightCyan" IsEditable="True" />
      </DataTemplate>
   </DataGridTemplateColumn.CellTemplate>
</DataGridTemplateColumn>  
<DataGridTextColumn Binding="{Binding ShippingAddress}" 
                    Width="100" 
                    Header="ShippingAddress" 
                    Visibility="Visible"/>

1 个答案:

答案 0 :(得分:6)

数据丢失的原因是CellTemplate仅提供非编辑功能,因此每当您在编辑新行时更改组合框中的值时,数据都没有设置,因为没有编辑模式实现,因此没有在后台创建对象。 DatagridTextColumn会自动将编辑内置到其中,这就是编辑此类单元后组合框可以工作的原因。

<DataGridTemplateColumn Header="ProductName" >
     <DataGridTemplateColumn.CellTemplate>
         <DataTemplate>
                 <ComboBox ItemsSource="{Binding ProductNamesList, 
                 RelativeSource={RelativeSource AncestorType=Window}}" 
                 SelectedValue="{Binding ProductName, Mode=TwoWay}"
                 IsSynchronizedWithCurrentItem="False"
                 IsEditable="False"
                 IsHitTestVisible="False" />
         </DataTemplate>
     </DataGridTemplateColumn.CellTemplate>
     <DataGridTemplateColumn.CellEditingTemplate>
         <DataTemplate>
             <ComboBox ItemsSource="{Binding ProductNamesList, 
                 RelativeSource={RelativeSource AncestorType=Window}}" 
                 Text="{Binding ProductName, Mode=TwoWay}"
                 IsSynchronizedWithCurrentItem="False"
                 IsEditable="True" />
         </DataTemplate>
     </DataGridTemplateColumn.CellEditingTemplate>
 </DataGridTemplateColumn>

仅当您希望用户在非编辑模式下查看组合框时,才需要组合框中的冗余。如果你不关心,你可以简单地写:

<DataGridTemplateColumn.CellTemplate>
    <DataTemplate>
        <TextBlock Text="{Binding ProductName}" />
    </DataTemplate>
 </DataGridTemplateColumn.CellTemplate>