如何:转换绑定的数据

更新:2007 年 11 月

本示例演示如何将转换应用于绑定中使用的数据。

要在绑定期间转换数据,必须创建一个实现 IValueConverter 接口的类,其中包括 ConvertConvertBack 方法。

示例

下面的示例演示一个日期转换器的实现,此日期转换器转换传入的日期值,使其只显示年月日。实现 IValueConverter 接口时,最好用 ValueConversionAttribute 属性来修饰此实现,以便向开发工具指示转换所涉及的数据类型,如下面的示例所示:

[ValueConversion(typeof(DateTime), typeof(String))]
public class DateConverter : IValueConverter
{
    public object Convert(object value, Type targetType, object parameter, CultureInfo culture)
    {
        DateTime date = (DateTime)value;
        return date.ToShortDateString();
    }

    public object ConvertBack(object value, Type targetType, object parameter, CultureInfo culture)
    {
        string strValue = value.ToString();
        DateTime resultDateTime;
        if (DateTime.TryParse(strValue, out resultDateTime))
        {
            return resultDateTime;
        }
        return value;
    }
}

一旦创建了转换器,即可将其作为一项资源添加到可扩展应用程序标记语言 (XAML) 文件中。在下面的示例中,src 映射到在其中定义 DateConverter 的命名空间。

<src:DateConverter x:Key="dateConverter"/>

最后,通过以下语法在绑定中使用转换器。在下面的示例中,TextBlock 的文本内容绑定到 StartDate,后者是外部数据源的一个属性。

<TextBlock Grid.Row="2" Grid.Column="0" Margin="0,0,8,0"
           Name="startDateTitle"
           Style="{StaticResource smallTitleStyle}">Start Date:</TextBlock>
<TextBlock Name="StartDateDTKey" Grid.Row="2" Grid.Column="1" 
    Text="{Binding Path=StartDate, Converter={StaticResource dateConverter}}" 
    Style="{StaticResource textStyleTextBlock}"/>

上述示例中引用的样式资源是在示例的资源部分定义的,该部分未显示在本主题中。有关上述代码示例所摘自的完整代码示例,请参见数据绑定演示

请参见

任务

如何:实现绑定验证

概念

数据绑定概述

其他资源

数据绑定示例

数据绑定帮助主题