我有这些: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 关注
- 162 浏览
添加回答
举报
0/150
提交
取消