[非专业翻译] Mapster - 双向 & 逆扁平映射
系列介绍
[非专业翻译] 是对没有中文文档进行翻译的系列博客,文章由机翻和译者自己理解构成,和原文相比有所有不同,但意思基本一致。
因个人能力有限,如有谬误之处还请指正,多多包涵。
正文
本文将说明 Mapster 如何配置双向映射与逆扁平映射
双向映射
如果需要 源到目标 和 目标到源 只进行一次配置,那么可以使用 ToWays
方法。
下面的配置的表现为:
- 源到目标时
dto.Code=poco.Id
- 目标到源时
poco.Id=dto.Code
TypeAdapterConfig<Poco, Dto>
.NewConfig()
.TwoWays()
.Map(dto => dto.Code, poco => poco.Id);
注意,TwoWays
方法必须在配置映射之前进行调用,否则在调用 TwoWays
方法之前的配置为单向映射配置,之后的配置为双向映射配置:
TypeAdapterConfig<Poco, Dto>
.NewConfig()
.Map(dto => dto.Foo, poco => poco.Bar) //<-- Poco->Dto 时生效
.TwoWays()
.Map(dto => dto.Foz, poco => poco.Baz); //<-- 双向映射生效
扁平化映射与逆扁平化映射
Mapster 默认将会把符合命名扁平化映射约束的成员进行映射。
例如,从 Staff
映射到 StaffDto
时,将会把 Supervisor
属性的 Name
属性映射到 StaffDto
的 SupervisorName
属性:
class Staff {
public string Name { get; set; }
public Staff Supervisor { get; set; }
...
}
struct StaffDto {
public string SupervisorName { get; set; }
}
但是如果想要 StaffDot
映射到 Staff
时,把 SupervisorName
映射到 Staff
的 Supervisor
属性的 Name
属性,那么就需要使用 Unflattening
方法进行显示的映射配置,实现 poco.Supervisor.Name=dto.SupervisorName
的效果:
TypeAdapterConfig<StaffDto, Staff>.NewConfig()
.Unflattening(true);
使用双向映射配置实现逆扁平化映射
使用 Toways
方法可以实现与 Unflattening
方法同样的效果:
-
源到目标时
dto.SupervisorName=poco.Supervisor.Name
-
目标到源时
poco.Supervisor.Name=dto.SupervisorName
TypeAdapterConfig<Staff, StaffDto>
.NewConfig()
.TwoWays();