为了账号安全,请及时绑定邮箱和手机立即绑定

AutoMapper 5.1 - 地图模型和扩展模型

AutoMapper 5.1 - 地图模型和扩展模型

C#
互换的青春 2023-07-22 18:25:56
我是 AutoMapper 的新手,我使用的是 5.1.1 版本。我尝试将模型列表与扩展模型列表进行映射。我得到空对象作为回报。我的源模型public class spt_detail{    public string Name { get; set; }    public string Age { get; set; }}我的目的地模型public class spt_detail_extended : spt_detail{       public string Mm1 { get; set; }    public string Mm2 { get; set; }}自动映射器代码spt_detail details = db.spt_detail.ToList();Mapper.Initialize(n => n.CreateMap<List<spt_detail>, List<spt_detail_extended>>());List<spt_creance_detail_enrichi> cenr = AutoMapper.Mapper.Map<List<spt_detail>, List<spt_detail_enrichi>>(details);问题:详细信息包含 8 行,但 cenr 0。有人可以帮助我吗?
查看完整描述

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);

如果您想映射其他模型,只需添加或编辑您的配置即可。


查看完整回答
反对 回复 2023-07-22
?
PIPIONE

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);



查看完整回答
反对 回复 2023-07-22
?
郎朗坤

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();

    }

}

希望这可以帮助!


查看完整回答
反对 回复 2023-07-22
  • 3 回答
  • 0 关注
  • 134 浏览

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信