如何使用转换器格式化列中的日期



我的数据网格中有一列,它正确绑定了数据并可以工作。现在,我想影响它的格式。所以我实现了一个转换器,并将其连接到现场。

<local:DateTimeFormat x:Key="IncludeTime" />
...
<igDP:Field Name="CreatedOn"
            Label="Label"
            Converter="{StaticResource IncludeTime}">
</igDP:Field>

显然,出了什么问题,因为我看不到窗户有什么变化。然而,当我在转换器中放置一个断点时,它会被击中,当我执行即时窗口中的语句时,它就会得到应该得到的字符串

public class DateTimeFormat : IValueConverter
{
  public object Convert(object v, Type t, object p, CultureInfo c)
  {
    if (v is DateTime)
      return System.Convert.ToDateTime(v).ToString("yyyy-MM-dd HH:mm:ss");
    return Binding.DoNothing;
  }
  ...
}

我的猜测是,我并没有将转换器的输出连接到标记的正确部分,但它让我无法解决它

请注意,我正在寻找一种将转换器应用于数据网格中的字段的通用方法,因此样式无法做到这一点(尽管可能有一种方法涵盖日期、时间和货币)。

我在尝试格式化字符串时遇到了同样的问题。我通过在FieldSettings上设置EditAsType属性来修复它。

EditAsType = "{x:Type core:String}"

当然,您可以将String替换为DateTime或其他类型。

核心名称空间:

xmlns:core = "clr-namespace:System;assembly=mscorlib"

您想要查看的任何格式都只需为XamDateTimeEditor创建一个样式并在其中指定格式(掩码)。您的代码是正确的,并返回了正确的值,但用于显示该值的编辑器需要注意这一点,否则它只会以默认格式显示值。(或ValueToDisplayTextConverter可用于在任何类型的控件中显示任何类型的文本。如数字编辑器中的字母数字文本等)

如果你使用一个简单的文本编辑器,你应该能够看到转换器返回的值。

<igEditors:XamDateTimeEditor Format="MM/dd/yy HH:mm:ss" Width="200" Height="30" Mask="mm/dd/yy hh:mm:ss" />

如果可以的话,我会尝试在这个场景中使用"ValueToDisplayTextConverters"。

xmlns:ie="http://infragistics.com/Editors"
...
<local:DateTimeFormat x:Key="IncludeTime" />
...
<igDP:Field Name="CreatedOn"
        Label="Label">
    <igDP:Field.Settings>
        <igDP:FieldSettings>
            <igDP:FieldSettings.EditorStyle>
                <Style TargetType="{x:Type ie:XamDateTimeEditor}" BasedOn="{StaticResource {x:Type ie:XamDateTimeEditor}}">
                    <Setter Property="ValueToDisplayTextConverter" Value="{StaticResource IncludeTime}" />
                </Style>
            </igDP:FieldSettings.EditorStyle>
        </igDP:FieldSettings>
    </igDP:Field.Settings>
</igDP:Field>

在现场安装转换器是可能的,尽管我不确定为什么它在你的情况下不起作用。然而,当我有一个比DateTime更复杂的类型/对象绑定到我本质上想对其执行ToString()的字段时,我发现在字段上放置转换器是有用的。

它还更改了记录的DataItem上的值的类型,这可能会在以后的排序或导出中导致问题。例如,在字段转换器中将数据转换为字符串意味着将对字符串值而不是DateTime进行排序。您可以通过编写自定义SortComparer来绕过它,但这是您必须编写的更多代码,这可能不是必需的。

相关内容

  • 没有找到相关文章

最新更新