0

我有一个 DataGrid,其 ItemsSource 设置为 DataTable。DataTable 有一个 DateTime 类型的列,如果特定单元格中的日期是某个值,我想显示信息文本(即“N/A”)。

我的第一个想法是以某种方式将单元格内容绑定到自身,并使用转换器,但我似乎无法让它正常工作,而且似乎应该有更好的方法。

此外,DataGrid 和 DataTable 都是动态生成的,因此必须在后面的代码中完成。

这是我最初尝试的代码:

// Create a new DataGridCellStyle
Style myStyle = new Style();
myStyle.TargetType = typeof(DataGridCell);

// Create the binding
Binding myBinding = new Binding();
myBinding.RelativeSource = RelativeSource.Self;
myBinding.Converter = new DateTimeToStringConverter();

// Add the Content setter
Setter mySetter = new Setter();
mySetter.Property = ContentProperty;  
mySetter.Value = myBinding;
myStyle.Setters.Add(setter);

// Set the Style and ItemsSource
myDataGrid.CellStyle = myStyle ;
myDataGrid.ItemsSource = myDataTable.DefaultView;

DateTimeToStringConverter 确实实现了 IValueConverter,但我猜问题出在绑定的某个地方,因为在显示 DataGrid 时从未真正调用过 DateTimeToStringConverter。

4

1 回答 1

1

首先,您将名称为setter的变量添加到 Setters 集合中,但您定义的是名称为mySetter的变量。这可能是一个原因,为什么实际上没有调用您的转换器。

此外,您的问题的解决方案会更复杂一些。实际上 Convert 得到一个 RowDataView 类型的值,其中包含整行的数据。转换器中没有关于实际绑定的 Column 或 Cell 的信息。

更好的是跳过 AutoGenerateColumns 并以编程方式生成它们。这是示例:

myDataGrid.ItemsSource = myDataTable.DefaultView;
myDataGrid.AutoGenerateColumns = false;

foreach (DataColumn column in myDataTable.Columns)
{
    Binding binding = new Binding(column.ColumnName)
        {
            Converter = new DateTimeToStringConverter()
        };
    DataGridColumn gridColumn = new DataGridTextColumn 
        { 
            SortMemberPath = column.ColumnName, 
            Header = column.ColumnName, 
            Binding = binding 
        };
    myDataGrid.Columns.Add(gridColumn);
}

当然,为了性能会更好,只在 DateTime 列中使用转换器。

于 2013-08-22T22:23:57.067 回答