AutoMapper官方文档(十一)【自定义类型转换器】

有时候,你需要完全控制一种类型到另一种类型的转换。这通常是当一个类型看起来不像另一个类型时,转换函数已经存在,并且您希望从“松散”类型转换为更强类型,比如源类型的字符串到目标类型Int32

例如,假设我们有一个来源类型:

public class Source
{
    public string Value1 { get; set; }
    public string Value2 { get; set; }
    public string Value3 { get; set; }
}

但是你想把它映射到:

public class Destination
{
    public int Value1 { get; set; }
    public DateTime Value2 { get; set; }
    public Type Value3 { get; set; }
}

如果我们试图将这两个类型按原样映射,AutoMapper将会抛出一个异常(在映射时间和配置检查时间),因为AutoMapper不知道从stringintDateTimeType的映射。 为了创建这些类型的映射,我们必须提供一个自定义的类型转换器,我们有三种方法:

void ConvertUsing(Func<TSource, TDestination> mappingFunction);
void ConvertUsing(ITypeConverter<TSource, TDestination> converter);
void ConvertUsing<TTypeConverter>() where TTypeConverter : ITypeConverter<TSource, TDestination>;

第一个选项就是任何一个接受一个源并返回一个目标的函数(也有几个重载)。 这适用于简单的情况,但对于较大的情况变得笨重。 在更困难的情况下,我们可以创建一个自定义的ITypeConverter<TSource, TDestination>

public interface ITypeConverter<in TSource, TDestination>
{
    TDestination Convert(TSource source, TDestination destination, ResolutionContext context);
}

并为AutoMapper提供一个自定义类型转换器的实例,或者简单的AutoMapper将在运行时实例化的类型。 我们上面的源/目标类型的映射配置然后变成:

[Test]
public void Example()
{
    Mapper.Initialize(cfg => {
      cfg.CreateMap<string, int>().ConvertUsing(s => Convert.ToInt32(s));
      cfg.CreateMap<string, DateTime>().ConvertUsing(new DateTimeTypeConverter());
      cfg.CreateMap<string, Type>().ConvertUsing<TypeTypeConverter>();
      cfg.CreateMap<Source, Destination>();
    });
    Mapper.AssertConfigurationIsValid();

    var source = new Source
    {
        Value1 = "5",
        Value2 = "01/01/2000",
        Value3 = "AutoMapperSamples.GlobalTypeConverters.GlobalTypeConverters+Destination"
    };

    Destination result = Mapper.Map<Source, Destination>(source);
    result.Value3.ShouldEqual(typeof(Destination));
}

public class DateTimeTypeConverter : ITypeConverter<string, DateTime>
{
    public DateTime Convert(string source, DateTime destination, ResolutionContext context)
    {
        return System.Convert.ToDateTime(source);
    }
}

public class TypeTypeConverter : ITypeConverter<string, Type>
{
    public Type Convert(string source, Type destination, ResolutionContext context)
    {
          return Assembly.GetExecutingAssembly().GetType(source);
    }
}

在第一个映射中,从stringInt32,我们只需使用内置的Convert.ToInt32函数(作为方法组提供)。 接下来的两个使用自定义的ITypeConverter实现。

自定义类型转换器的真正威力在于AutoMapper在任何映射类型上找到源/目标对时都可以使用它们。 我们可以构建一套自定义类型转换器,在其他映射配置上使用,而不需要任何额外的配置。 在上面的例子中,我们再也不需要指定string/int转换。 在自定义值解析器必须在类型成员级别配置的情况下,自定义类型转换器是全局范围的。

系统类型转换器

.NET Framework还通过TypeConverter类支持类型转换器的概念。 AutoMapper支持这些类型的转换器,进行配置检查和映射,而不需要任何手动配置。 AutoMapper使用TypeDescriptor.GetConverter方法来确定是否可以映射源/目标类型对。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
AutoMapper是一个用于对象映射的开源库。它可以帮助简化对象之间的转换过程,减少手动编写重复的代码。通过配置映射规则,AutoMapper可以自动将一个对象的属性值复制到另一个对象中对应的属性上,而不需要手动逐个属性进行赋值。 使用AutoMapper,你可以定义映射规则,包括源类型和目标类型以及它们之间的属性映射关系。一旦配置好映射规则,你可以使用简单的API将源对象映射到目标对象上。 以下是一个使用AutoMapper的示例: ```csharp // 定义源类型和目标类型 public class SourceObject { public string Name { get; set; } public int Age { get; set; } } public class DestinationObject { public string Name { get; set; } public int Age { get; set; } } // 配置映射规则 var config = new MapperConfiguration(cfg => { cfg.CreateMap<SourceObject, DestinationObject>(); }); // 创建映射 var mapper = config.CreateMapper(); // 创建源对象 var source = new SourceObject { Name = "John", Age = 30 }; // 使用映射进行对象映射 var destination = mapper.Map<SourceObject, DestinationObject>(source); // 输出目标对象属性值 Console.WriteLine(destination.Name); // 输出:John Console.WriteLine(destination.Age); // 输出:30 ``` 通过使用AutoMapper,你可以简化对象之间的映射过程,提高开发效率。它支持各种复杂的映射场景,并且可以通过自定义转换来处理更复杂的映射逻辑。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值