我是第一次在WPF上开展一个程序。我在GridView模式下有一个ListView,显示来自绑定数据集的数据(从数据库中获取)。
在我的数据库中,“出生日期”不是必填字段。因此,任何没有dob的记录都将值设置为DateTime.MinValue
。在每个最小值日期中,日期在单元格中显示为01/01/0001。我正在尝试找到一种方法来格式化单元格,以便DateTime.MinValue
不显示,或用MinValue
替换每个""
。
我的想法是使用日期所在的文本块的“已加载”事件并替换“01/01/0001”的每个实例,或者在将数据集发送到GridView之前循环遍历数据集并删除/替换它们那里。我没有运气弄清楚怎么做。
我对GridView的xaml代码是:
<Grid>
<ListView x:Name="resultsListView" GridViewColumnHeader.Click="GridViewColumnHeaderClickedHandler" Margin="0,54,0,28" ItemsSource="{Binding Path=Table}">
<ListView.View>
<GridView>
<GridViewColumn DisplayMemberBinding="{Binding Path=LastName}"
Header="Last Name"
Width="150"/>
<GridViewColumn DisplayMemberBinding="{Binding Path=FirstName}"
Header="First Name"
Width="100"/>
<GridViewColumn DisplayMemberBinding="{Binding Path=MiddleName}"
Header="Middle Name"
Width="100"/>
<GridViewColumn Header="Date of Birth" Width="100">
<GridViewColumn.CellTemplate>
<DataTemplate>
<TextBlock TextAlignment="Justify" Text="{Binding Path=DateOfBirth, StringFormat='{}{0:MM/dd/yyyy}'}" Loaded="TextBlock_Loaded" />
</DataTemplate>
</GridViewColumn.CellTemplate>
</GridViewColumn>
</GridView>
</ListView.View>
</ListView>
</Grid>
DataSet的代码:
private void FillListView(DataSet ds)
{
if (resultsListView.Items.Count != 0)
{
resultsListView.Items.Clear();
}
resultsListView.DataContext = ds.Tables[0].DefaultView;
}
有关如何在我的GridView中显示DateTime.MinValue
的空白的任何建议都将非常感谢!
答案 0 :(得分:2)
我会创建一个处理此问题的IValueConverter
,并将其包含在绑定表达式中。
在您的资源中:
<local:DateTimeConverter x:Key="DateTimeConverter" />
然后更新你的绑定:
<TextBlock Text="{Binding Path=DateOfBirth,
Converter={StaticResource DateTimeConverter},
ConverterParameter='MM/dd/yyyy'}" />
然后定义类:
public class DateTimeConverter : IValueConverter
这有两种方法。您只需要实现Convert
(除非您计划使用双向绑定)。在这个方法中,你可以通过参数获取格式字符串(因为我已经传递了上面的绑定表达式)并检查DateTime.MinValue
并返回一个空字符串。