您好,登录后才能下订单哦!
密码登录
登录注册
点击 登录注册 即表示同意《亿速云用户服务条款》
(一)什么是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);
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。