zoukankan      html  css  js  c++  java
  • [非专业翻译] Mapster

    [非专业翻译] Mapster - 映射只读属性

    系列介绍

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

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

    正文

    本文将说明 Mapster 如何映射只读属性

    映射非公开 set 的属性

    Mapster 默认会自动映射非公开 set 的属性:

    public class Order {
        public string Id { get; set; }
        public ICollection<OrderItem> Items { get; private set; }
    }
    

    [UseDestinationValue] 特性标签

    给属性添加特性标签 [UseDestinationValue] ,未指定 set 的属性也能进行映射:

    public class Order {
        public string Id { get; set; }
    
        [UseDestinationValue]
        public ICollection<OrderItem> Items { get; } = new List<OrderItem>();
    }
    

    基于约定配置映射

    如果希望所有未指定 setICollection<> 都参与映射,那么可以使用 UseDestinationValue 方法进行配置:

    TypeAdapterConfig.GlobalSettings.Default
        .UseDestinationValue(member => member.SetterModifier == AccessModifier.None &&
                                       member.Type.IsGenericType &&
                                       member.Type.GetGenericTypeDefinition() == typeof(ICollection<>));
    
    目前学习.NET Core 最好的教程 .NET Core 官方教程 ASP.NET Core 官方教程
    如果您认为这篇文章还不错或者有所收获,您可以点击右下角的【推荐】支持,或请我喝杯咖啡【赞赏】,这将是我继续写作,分享的最大动力!
    声明:原创博客!请在转载时在文章开头注明本人博客地址。如发现错误,欢迎批评指正。凡是转载于本人的文章,不能设置打赏功能,如有特殊需求请与本人联系!
  • 相关阅读:
    提升ASP.NET性能
    人性的弱点
    墨菲定律
    沟通
    网站
    程序员思维模式
    CSS
    HTML
    路由和数据传递(04)
    Sql Server中查看所有数据库,表名,字段名以及字段类型
  • 原文地址:https://www.cnblogs.com/staneee/p/14913664.html
Copyright © 2011-2022 走看看