如何在AutoMapper 5中的不同映射中重用ValueResolver?

时间:2016-07-13 12:50:55

标签: automapper automapper-5

我刚尝试将AutoMapper升级到5.0.2,但遇到了障碍。

根据migration docs,值解析器现在可以访问目标对象:

  

值解析程序的签名已更改为允许访问源/目标模型。

这导致每个值解析器都与一个目标类型绑定。

但是,我们的一些值解析器用于多种目标类型。我们有例如在映射我们的DTO的所有ID属性期间使用的解析器。解析器通过注入解析器的服务修改ID。

如何在AutoMapper 5中定义可重用的值解析器,以便我不必为每个目标类型创建具有完全相同实现的专用解析器?

注意:使用值解析器而不是直接操作值的主要原因是依赖注入。根据{{​​3}},值解析器是在映射期间使用依赖注入服务的最佳方式。

2 个答案:

答案 0 :(得分:5)

目的地类型可以是"对象":

public class FooResolver : IValueResolver<object, object, string> {}

或者它可以更具体:

public class FooResolver : IValueResolver<IEntity, object, string> {}

由于为IValueResolver定义了方差,您可以将基类型放在前两个通用参数中。

答案 1 :(得分:-1)

早上好,我认为最好的方法是按以下方式使用泛型:

public class FooResolver<TSource, TDestination> : IValueResolver<TSource, TDestination, string>
{
   private readonly Dictionary<Type, int> typeDictionary;

   public FooResolver()
   {
      typeDictionary = new  Dictionary<Type, int>
     {
        {typeof(FooA), 0},
        {typeof(FooB), 1}
     };
   }

   pulic string Resolve(TSource source, TDestination destination, string destMember, 
   ResolutionContext context)
   {
      switch (typeDictionary[source.GetType()])
      {
         case 0:
           var fooA = ((FooA)Convert.ChangeType(source, typeof(FooA)));
           //custom code
         break;
         case 1:
           var fooB = ((FooB)Convert.ChangeType(source, typeof(FooB)));
           //custom code
         break;
      }

      return string_value;
   }
}

在映射过程中,您只需提供源和目标的实际类型,例如 act.MapFrom<FooResolver<FooA, FooADestination>>