3 回答
TA贡献1836条经验 获得超3个赞
将spt_detail映射到spt_detail_extended。
您应该仅为模型创建映射规则,如下所示:
Mapper.Initialize(cfg => { cfg.CreateMap<spt_detail, spt_detail_extended>(); });
之后,您应该使用以下结构:
List<spt_detail_extended> extendeds = Mapper.Map<List<spt_detail_extended>>(details);
如果您想映射其他模型,只需添加或编辑您的配置即可。
TA贡献1829条经验 获得超9个赞
不要映射列表,而是像这样映射:
Mapper.Initialize(n => n.CreateMap<spt_detail, spt_detail_extended>());
你打电话去做地图会保持不变:
List<spt_detail_extended> cenr = AutoMapper.Mapper.Map<List<spt_detail>, List<spt_detail_extended>>(details);
TA贡献1921条经验 获得超9个赞
你在这里错过了两个步骤。
第一个是您需要初始化业务对象的列表,而不是仅初始化单个业务对象。您从数据库中检索列表(使用 .Tolist())
这是我如何初始化对象的示例:
List <SptDetail> details = new List <SptDetail> {
new SptDetail {
Age = "10",
Name = "Marion"
},
new SptDetail {
Age = "11",
Name = "Elisabeth"
}
};
第二个失误是您正在映射 lits,我建议您使用单个业务类对象,如下所示:
Mapper.Initialize(n => n.CreateMap<SptDetail, SptDetailExtended>()
.ForMember(obj => obj.ExProp1, obj => obj.MapFrom(src => src.Name))
.ForMember(obj => obj.ExProp2, obj => obj.MapFrom(src => src.Age)));
而洞故事的关键是使用。ForMember指定 wich 成员的位置,因为属性不具有相同的名称。
这是一个代码示例,运行起来就像一个魅力:
internal class Program
{
public static List<SptDetailExtended> InitializeExtendedObjects()
{
var details = new List<SptDetail>
{
new SptDetail
{
Age = "10",
Name = "Marion"
},
new SptDetail
{
Age = "11",
Name = "Elisabeth"
}
};
//this is wrong db.spt_detail.ToList();
Mapper.Initialize(n => n.CreateMap<SptDetail, SptDetailExtended>()
/*you need to use ForMember*/ .ForMember(obj => obj.ExProp1, obj => obj.MapFrom(src => src.Name))
.ForMember(obj => obj.ExProp2, obj => obj.MapFrom(src => src.Age)));
//instead of this Mapper.Initialize(n => n.CreateMap<List<spt_detail>, List<spt_detail_extended>>());
//change your mapping like following too
var cenr = Mapper.Map<List<SptDetailExtended>>(details);
return cenr;
}
private static void Main(string[] args)
{
var result = InitializeExtendedObjects();
foreach (var sptDetailExtended in result)
{
Console.WriteLine(sptDetailExtended.ExProp1);
Console.WriteLine(sptDetailExtended.ExProp2);
}
Console.ReadLine();
}
}
希望这可以帮助!
- 3 回答
- 0 关注
- 134 浏览
添加回答
举报