NET-Core中使用OOM框架AutoMapper的使用介绍

42次阅读

共计 1219 个字符,预计需要花费 4 分钟才能阅读完成。

(一)什么是 OOM:
OOM 顾名思义,Object-Object-Mapping 实体间相互转换,AutoMapper 其意义在于帮助你无需手动的转换简单而又麻烦的实体间关系。

(二)AutoMapper 是什么:
AutoMapper 是基于对象到对象约定的映射工具,常用于(但并不仅限制于)把复杂的对象模型转为 DTO,一般用于 ViewModel 模式和跨 服务范畴。

(三)在.NET Core 项目中如何使用它:
1. 通过 Nuget 安装 AutoMapper 到项目:Install-Package AutoMapper
2. 定义好 Model 类和 DTO 类:
`//Model 类
public class ProjectEntity
{

public int ID {get; set;}

public string ProjectName {get; set;}

public string ProjectImg {get; set;}

public string ProjectCreateDate {get; set;}

public List<ProjectTaskEntity> Tasks {get; set;}

}
`

`//DTO 类
public class ProjectDto
{

public int ProjectID {get; set;}

public string ProjectName {get; set;}

public string ProjectImg {get; set;}

public string ProjectCreateDate {get; set;}

public List<ProjectTaskDto> Tasks {get; set;}

}`

3. 配置映射关系,在 ConfigureServices 方法中加入映射关系:
`// 配置为双向映射
CreateMap<ProjectTaskDto, ProjectTaskEntity>()
.ReverseMap();`

4. 如果 Model 类中的部分字段与 DTO 的字段不一致时,如何映射呢?
`CreateMap<ProjectDto, ProjectEntity>()
.ReverseMap()
.ForMember(des => des.Date, opt => opt.MapFrom(src => src.CreateTime.ToString(“yyyy-MM-dd hh:mm:ss”)));`

5. 执行映射转换:
`// 获取实体对象
ProjectEntity _projectEntity = GetProjectsByDB(projectid);
// 将实体对象映射到 DTO
ProjectDto _projectDto = _mapper.Map<ProjectDto>(_projectEntity);`

6. 如果是集合该如何转换呢?
var ProjectEntitys = AutoMapper.Mapper.Map<List< ProjectEntity>, List< ProjectDto >>(_projectEntitys);

正文完
 0