温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

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

发布时间:2020-07-12 21:20:42 来源:网络 阅读:206 作者:wx5d37d5fd4aa62 栏目:编程语言

(一)什么是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);
向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI