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 關注
- 179 瀏覽
添加回答
舉報