我在 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"/>