[非专业翻译] Mapster - 双向 & 逆扁平映射

[非专业翻译] 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 属性映射到 StaffDtoSupervisorName 属性:

class Staff {
    public string Name { get; set; }
    public Staff Supervisor { get; set; }
    ...
}

struct StaffDto {
    public string SupervisorName { get; set; }
}

但是如果想要 StaffDot 映射到 Staff 时,把 SupervisorName 映射到 StaffSupervisor 属性的 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();
上一篇:RunLoop


下一篇:[非专业翻译] Mapster - 调试