我的映射器中有以下一行:
我正在尝试从一个具有一个名为Result的属性的模型映射到一个具有一个结果列表的模型。
到目前为止,我有以下内容:
options.CreateMap<Contract.Dto.Result, List<Result>>(MemberList.Source).ConvertUsing<ResultConverter>();
internal class ResultConverter : ITypeConverter<Contract.Dto.Result, List<Result>>
{
public List<Result> Convert(Contract.Dto.Result source, List<Result> destination, ResolutionContext context)
{
destination.Add(context.Mapper.Map<Contract.Dto.Result, Result>(source));
return destination;
}
}
但是,在调试时,永远不会命中ResultConverter。 关于如何从单个对象映射到对象列表,有人可以解决吗?在此对象列表中将永远只有一个对象,但其他约束阻止我修改模型。
答案 0 :(得分:1)
我设法使它在我创建的很小的类库中工作。我注意到的一些位可能会破坏您的代码:
在要映射的任何地方都不要提及
var config = new MapperConfiguration(options =>
{
options.CreateMap<Contract.Dto.Result, List<Result>>(MemberList.Source).ConvertUsing<ResultConverter>();
options.CreateMap<Contract.Dto.Result, Result>(MemberList.Source);
});
在您的转换器中,我将其更改为使用新的结果列表,而不是目的地
public List<Result> Convert(Contract.Dto.Result source, List<Result> destination, ResolutionContext context)
{
var listOfResults = new List<Result>();
var result = context.Mapper.Map<Contract.Dto.Result, Result>(source);
listOfResults.Add(result);
return listOfResults;
}
在实际使用地图时,只需确保您具有正确的语法
var result = new Contract.Dto.Result();
var expected = mapper.Map<List<Result>>(result);
此外,如果使用的是IOC,请确保已注册了连接器。下面的Autofac代码示例
builder.RegisterType<ResultConverter>().AsSelf();
builder.Register(context => new MapperConfiguration(options=>
{
options.CreateMap<Contract.Dto.Result, List<Result>>(MemberList.Source).ConvertUsing<ResultConverter>();
options.CreateMap<Contract.Dto.Result, Result>(MemberList.Source);
})).AsSelf().SingleInstance();
builder.Register(c =>
{
//This resolves a new context that can be used later.
var context = c.Resolve<IComponentContext>();
var config = context.Resolve<MapperConfiguration>();
return config.CreateMapper(context.Resolve);
}).As<IMapper>().InstancePerLifetimeScope();
正如下面评论中提到的OP,还请确保使用正确的类型,在这种情况下为List <> vs IList <>
在您的项目中尝试所有这些方法,希望能够解决您的问题。如果没有告知我,我可以再看一遍。
答案 1 :(得分:-4)
我从未使用过自动映射器。您可以尝试一下,如果有效,请告诉我
//Use this method.
public void Map(object PreEqual, string PreEqProperty, object PostEqual, string PostEqProperty)
{
PreEqual.GetType().GetProperty(PreEqProperty).SetValue(PreEqual, PostEqual.GetType().GetProperty(PostEqProperty).GetValue(PostEqual, null), null);
}
//Use Map method somewhere you want, like this:
//myRefObj is your source object and myRefProp is its property that you want to map to other objects.
foreach(SomeType item in CollectionOfSomeType)
{
Map(item, "myRefProp", myRefObj, "myRefProp");
}
我认为它将适用于原始类型。您可以尝试让我知道是否可行吗?