我有這些:public class FamilyHead{ public Guid HeadId { get; set; } public string Name { get; set; }}public class Citizen{ public Guid Id { get; set; } public string Name { get; set; } public short Age { get; set; } // more properties [ForeignKey("FamilyHead")] public Guid HeadId { get; set; } public virtual FamilyHead FamilyHead { get; set; }}public class CitizenDTO{ public Guid Id { get; set; } public string Name { get; set; } public short Age { get; set; } public Guid HeadId public string HeadName { get; set; }}如果它是單個實例,我可以通過擴展方法手動映射它:public static CitizenDTO ToDTO(this Citizen citizen){ if (citizen == null) return null; return new CitizenDTO { Id = citizen.Id, Name = citizen.Name, HeadId = citizen.HeadId, HeadName = citizen.FamilyHead.Name } }var dto = aCitizen.ToDTO();但是如何映射公民名單呢?我認為Select()可能會完成這項工作,但我只知道如果模型和 dto 具有相同的結構,該怎么做。像這個例子:IEnumerable<int> integers = new List<int>() { 1, 2, 3, 4, 5 };IEnumerable<string> strings = integers.Select(i => i.ToString());那么如何映射一個列表呢?
2 回答

長風秋雁
TA貢獻1757條經驗 獲得超7個贊
Select()
您可以像在問題中使用的那樣使用 Linq string
,無需編寫長擴展方法
IEnumerable<CitizenDTO> dto = citizens.Select(x => x.ToDTO());

GCT1015
TA貢獻1827條經驗 獲得超4個贊
我在完成問題之前找到了答案。只需遍歷列表并向其添加映射的 DTO。傻我
// Extension method
public static IEnumerable<CitizenDTO> ToDTO(this IEnumerable<Citizen> citizens)
{
if (citizen == null) return null;
var dto = new List<CitizenDTO>();
foreach(var citizen in citizens) {
dto.Add(citizen.ToDTO());
}
return dto;
}
// How to use
IEnumerable<CitizenDTO> result = listOfCitizens.ToDTO();
- 2 回答
- 0 關注
- 203 瀏覽
添加回答
舉報
0/150
提交
取消