我刚尝试将AutoMapper升级到5.0.2,但遇到了障碍。
根据migration docs,值解析器现在可以访问目标对象:
值解析程序的签名已更改为允许访问源/目标模型。
这导致每个值解析器都与一个目标类型绑定。
但是,我们的一些值解析器用于多种目标类型。我们有例如在映射我们的DTO的所有ID属性期间使用的解析器。解析器通过注入解析器的服务修改ID。
如何在AutoMapper 5中定义可重用的值解析器,以便我不必为每个目标类型创建具有完全相同实现的专用解析器?
注意:使用值解析器而不是直接操作值的主要原因是依赖注入。根据{{3}},值解析器是在映射期间使用依赖注入服务的最佳方式。
答案 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>>