使用WPF数据绑定将NULL值显示为“NULL”的最简单方法是什么?

我有这个遗留数据库,我正在使用 Linq to sql构建自定义查看器.

现在,表中的某些字段可以具有NULL值.
在DataTemplate中使用常规数据绑定(为ORM Designer生成的类型键入)

<TextBlock Text="{Binding Path=columnX}"/>

如果columnX的值为NULL,则不显示任何内容. (似乎是WPF约定)如果值为NULL,我想显示“NULL”. (相当于column_value ??“NULL”)

我可以使用转换器

<TextBlock Text="{Binding Path=columnX,Converter={StaticResource nullValueConverter}}"/>

转换器类

class NullValueConverter : IValueConverter
{
  public object Convert(object value,Type targettype,object parameter,System.Globalization.CultureInfo culture)
  {
    if (value == null)
      return "NULL";
    ...

但这似乎太多了.此逻辑也需要在现有的非平凡转换器中重复.

有没有一个快速方法来实现这一目标?

解决方法

绑定类有一个名为TargetNullValue的属性,如果绑定返回NULL值,则可以使用该属性替换其他内容.你的榜样变成: –
<TextBlock Text="{Binding Path=columnX,TargetNullValue=My Substitute Text}"/>

Binding类的另一个属性也称为FallbackValue.如果无法解析(即未找到)绑定表达式,则这将是替代值,例如,当您使用的路径(示例中的columnX)不是数据上下文或源的成员时.

更新(Gishu):需要.NET Framework 3.5 SP1下载53MB.没有它,上面的代码将无法编译. TargetNullValue是Binding类的新增功能.

相关文章

SELECT a.*,b.dp_name,c.pa_name,fm_name=(CASE WHEN a.fm_n...
if not exists(select name from syscolumns where name=&am...
select a.*,pano=a.pa_no,b.pa_name,f.dp_name,e.fw_state_n...
要在 SQL Server 2019 中设置定时自动重启,可以使用 Window...
您收到的错误消息表明数据库 &#39;EastRiver&#39; 的...
首先我需要查询出需要使用SQL Server Profiler跟踪的数据库标...