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

    系列介绍

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

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

    正文

    本文将说明 Mapster 如何配置值的映射

    计算值

    可以使用 Map 方法指定计算值的逻辑。

    例如,将 FirstNameLastName 拼接生成 FullName:

    TypeAdapterConfig<Poco, Dto>.NewConfig()
                                .Map(dest => dest.FullName, src => src.FirstName + " " + src.LastName);
    

    变换值

    Map 方法只能对单个成员指定映射逻辑,使用 AddDestinationTransform 方法可以根据类型指定映射逻辑,例如替换字符串等操作。

    其实在 Mapster 中,只要在映射赋值操作执行之前,可以对映射的值执行任何操作。

    字符串 Trim

    TypeAdapterConfig<TSource, TDestination>.NewConfig()
            .AddDestinationTransform((string x) => x.Trim());
    

    null字符串替换为空字符串

    TypeAdapterConfig<TSource, TDestination>.NewConfig()
            .AddDestinationTransform((string x) => x ?? "");
    

    null集合返回空集合

    config.Default.AddDestinationTransform(DestinationTransform.EmptyCollectionIfNull);
    

    传递动态值

    在一些情况下,可能需要传递动态传递值,可以通过调用 MapContext.Current.Parameters 来获取动态传递的值。

    例如设置 CreatedBy 字段为当前登录用户名称,从 MapContext.Current.Parameters["user"] 映射:

    TypeAdapterConfig<Poco, Dto>.NewConfig()
                                .Map(dest => dest.CreatedBy,
                                     src => MapContext.Current.Parameters["user"]);
    

    为了动态传递值,需要在调用映射之前使用 BuildAdapter 方法,并且在这之后调用 AddParameters 方法添加值。

    下面的例子展示了如何传递动态参数 user

    var dto = poco.BuildAdapter()
                  .AddParameters("user", this.User.Identity.Name)
                  .AdaptToType<Dto>();
    
    目前学习.NET Core 最好的教程 .NET Core 官方教程 ASP.NET Core 官方教程
    如果您认为这篇文章还不错或者有所收获,您可以点击右下角的【推荐】支持,或请我喝杯咖啡【赞赏】,这将是我继续写作,分享的最大动力!
    声明:原创博客!请在转载时在文章开头注明本人博客地址。如发现错误,欢迎批评指正。凡是转载于本人的文章,不能设置打赏功能,如有特殊需求请与本人联系!
  • 相关阅读:
    关于vue无法侦听数组及对象属性的变化的解决方案
    web js导出csv 文件(使用a标签)
    微信小程序-获取用户信息和openid,session_key,
    H5适配 iponex
    项目使用iconfont图标
    锚点链接,组件库中锚点实现
    前端的调试工具和node调试工具
    前端模块化 CommonJS AMD CMD ES6
    支付宝小程序
    个人创用 UA 列表
  • 原文地址:https://www.cnblogs.com/staneee/p/14913685.html
Copyright © 2011-2022 走看看