Gis*_*shu 6 data-binding wpf linq-to-sql
我有这个遗留数据库,我正在使用Linq to Sql构建自定义查看器.
现在,表中的某些字段可以具有NULL值.在DataTemplate中使用常规数据绑定(为ORM Designer生成的类型键入)
<TextBlock Text="{Binding Path=columnX}"/>
Run Code Online (Sandbox Code Playgroud)
如果columnX的值为NULL,则不显示任何内容.(似乎是WPF约定)如果值为NULL,我想显示"NULL".(相当于column_value ?? "NULL")
我可以使用转换器
<TextBlock Text="{Binding Path=columnX, Converter={StaticResource nullValueConverter}}"/>
Run Code Online (Sandbox Code Playgroud)
转换器类
class NullValueConverter : IValueConverter
{
public object Convert(object value, Type targetType, object parameter, System.Globalization.CultureInfo culture)
{
if (value == null)
return "NULL";
...
Run Code Online (Sandbox Code Playgroud)
但这似乎太多了.此逻辑也需要在现有的非平凡转换器中重复.
有没有一个快速的方法来实现这一目标?
Rhy*_*hys 18
绑定类有一个名为TargetNullValue的属性,如果绑定返回NULL值,则可以使用该属性替换其他内容.你的榜样变成: -
<TextBlock Text="{Binding Path=columnX, TargetNullValue=My Substitute Text}"/>
Run Code Online (Sandbox Code Playgroud)
Binding类的另一个属性也称为FallbackValue.如果无法解析(即未找到)绑定表达式,这将是替换值,例如,当您使用的路径(示例中的columnX)不是数据上下文或源的成员时.
更新(Gishu):需要.NET Framework 3.5 SP1 53MB下载.没有它,上面的代码将无法编译.TargetNullValue是Binding类的新增功能.