[非专业翻译] Mapster - 映射忽略

[非专业翻译] Mapster - 映射忽略

系列介绍

[非专业翻译] 是对没有中文文档进行翻译的系列博客,文章由机翻和译者自己理解构成,和原文相比有所有不同,但意思基本一致。

因个人能力有限,如有谬误之处还请指正,多多包涵。

正文

本文将说明 Mapster 的 映射忽略成员

基本的映射忽略

Mapster 默认会自动映射所有符合规则的成员。如果想要在映射时忽略某一个成员,可以使用 Ignore 方法进行配置:

TypeAdapterConfig<TSource, TDestination>
    .NewConfig()
    .Ignore(dest => dest.Id);

基于规则的映射忽略

使用 IgnoreMember 方法可以根据某个条件决定是否映射成员:

TypeAdapterConfig.GlobalSettings.Default
    .IgnoreMember((member, side) => !validTypes.Contains(member.Type));

更多信息请参阅 基于规则映射成员

忽略未显示映射的成员

使用 IgnoreNonMapped 方法可以忽略所有未显示配置映射的成员。

例如,只映射 IdName

TypeAdapterConfig<TSource, TDestination>
    .NewConfig()
    .Map(dest => dest.Id, src => src.Id)
    .Map(dest => dest.Name, src => src.Name)
    .IgnoreNonMapped(true);

通过特性标签配置映射忽略

当一个成员有 [AdaptIgnore] 特性标记时,这个成员将不会被映射:

public class Product {
    public string Id { get; set; }
    public string Name { get; set; }

    [AdaptIgnore]
    public decimal Price { get; set; }
}

更多信息请参阅 使用特性标签配置映射

不映射满足条件的成员

使用 IgnoreIf 方法,当满足条件时将忽略此成员的映射:

TypeAdapterConfig<TSource, TDestination>
    .NewConfig()
    .IgnoreIf((src, dest) => !string.IsNullOrEmpty(dest.Name), dest => dest.Name);

不映射空值成员

Mapster 默认映射时会将 源对象的所有成员映射到目标对象,如果不想映射空值,那么可以使用 IgnoreNullValues 方法进行配置:

TypeAdapterConfig<TSource, TDestination>
    .NewConfig()
    .IgnoreNullValues(true);
posted @ 2021-06-29 08:24  玩双截棍的熊猫  阅读(821)  评论(0编辑  收藏  举报