Easy-DotNET Easy-DotNET
🏠首页
  • 知识地图
  • 源码脑图

    • 总览
    • Program
    • WebApplication
    • Host主机
    • WebHost主机
    • 依赖注入
    • Autofac
    • Middleware中间件
    • RateLimiter限制速率
    • 响应缓存、请求解压缩
  • 设计初衷
  • 克隆
  • 类型转换
  • 日期时间
  • IO流
  • 工具类
  • 语言特性
  • 集合类
  • Codec编码
  • 文本操作
  • 数学
  • 图片
  • 网络
  • Emoji表情
  • C# 12
  • C# 11
  • C# 10
  • C# 9.0
  • C# 8.0
  • C# 早期版本
  • C# 教程
  • ORM
  • 定时任务
  • 日志
  • 认证与授权
  • Swagger
  • 对象映射
  • 熔断重试限流
  • 缓存
  • 注册发现
  • 网关
  • GraphQL
  • 更多
  • Docker

    • 简介
    • Adminer
    • Apisix
    • Apollo
    • Cassandra
    • Cerebro
    • ClickHouse
    • Consul
    • EasyMock
    • Elasticsearch
    • Emqx
    • FastDFS
    • Flink
    • Gitlab
    • Jenkins
    • Jrebel
    • MariaDB
    • MySQL
    • Percona
    • Phpmyadmin
    • PostgreSQL
    • Redis
  • Linux

    • 查看Linux系统信息
    • CentOS7调整磁盘分区
    • IO压测
    • 图形化监控工具Cockpit
  • 总览
  • 列表

    • 算法数据结构
    • API
    • 应用框架
    • 应用模板
    • 操作系统
    • 工作流
    • 入门套件
    • 示例
    • 人工智能
    • 程序集
    • Assets
    • 认证授权
    • Blazor
    • 区块链
    • 书籍
    • 自动构建
    • 报表
    • 缓存
    • 日历
    • 聊天
    • CLI
    • CLR
    • CMS
    • 代码分析和指标
    • 代码片段
    • 压缩
    • 持续集成
    • 密码学
    • 数据库
    • 数据库驱动
    • 日期时间
    • 反编译
    • 部署
    • DirectX
    • 分布式计算
    • DLR
    • 文档
    • 电商支付
    • 模拟器
    • 环境管理
    • ETL
    • 事件消息
    • Exception
    • 扩展
    • 函数式编程
    • 游戏引擎
    • GIS
    • Git工具
    • 绘图
    • GraphQL
    • GUI
    • HTML-CSS
    • HTTP
    • IDE
    • 图片处理
    • 安装工具
    • 交互式编程
    • 国际化
    • 互操作性
    • IoC
    • JS引擎
    • 日志
    • 机器学习和数据科学
    • Markdown
    • 邮件
    • 数学
    • 媒体
    • 指标
    • 微型框架
    • 最小化器
    • MVVM
    • 网络
    • 对象映射
    • Office
    • OpenAI
    • ORM
    • 包管理器
    • PDF
    • 性能分析工具
    • 协议
    • 推送通知
    • SQL构建器
    • 消息队列
    • RPC
    • 响应式编程
    • 实时通信
    • 正则表达式
    • 任务调度
    • SDK和API
    • 搜索引擎
    • 序列化
    • SMS
    • 状态机
    • 静态站点生成
    • 强命名
    • 风格指南
    • 模板引擎
    • 测试
    • 工具
    • 交易
    • UI自动测试
    • Visual Studio 插件
    • Web浏览器
    • Web框架
    • WebServers
    • WebSocket
    • Windows服务
    • WPF
    • 解析器
    • 源码生成
    • 其他
    • 资源
  • AspNetCore面试题
  • Elasticsearch面试题
  • MongoDB面试题
  • MySql面试题
  • Nginx面试题
  • RabbitMQ面试题
  • Redis面试题
  • 设计模式
  • 微服务
🧑‍💻.NET Blog
GitHub (opens new window)
🏠首页
  • 知识地图
  • 源码脑图

    • 总览
    • Program
    • WebApplication
    • Host主机
    • WebHost主机
    • 依赖注入
    • Autofac
    • Middleware中间件
    • RateLimiter限制速率
    • 响应缓存、请求解压缩
  • 设计初衷
  • 克隆
  • 类型转换
  • 日期时间
  • IO流
  • 工具类
  • 语言特性
  • 集合类
  • Codec编码
  • 文本操作
  • 数学
  • 图片
  • 网络
  • Emoji表情
  • C# 12
  • C# 11
  • C# 10
  • C# 9.0
  • C# 8.0
  • C# 早期版本
  • C# 教程
  • ORM
  • 定时任务
  • 日志
  • 认证与授权
  • Swagger
  • 对象映射
  • 熔断重试限流
  • 缓存
  • 注册发现
  • 网关
  • GraphQL
  • 更多
  • Docker

    • 简介
    • Adminer
    • Apisix
    • Apollo
    • Cassandra
    • Cerebro
    • ClickHouse
    • Consul
    • EasyMock
    • Elasticsearch
    • Emqx
    • FastDFS
    • Flink
    • Gitlab
    • Jenkins
    • Jrebel
    • MariaDB
    • MySQL
    • Percona
    • Phpmyadmin
    • PostgreSQL
    • Redis
  • Linux

    • 查看Linux系统信息
    • CentOS7调整磁盘分区
    • IO压测
    • 图形化监控工具Cockpit
  • 总览
  • 列表

    • 算法数据结构
    • API
    • 应用框架
    • 应用模板
    • 操作系统
    • 工作流
    • 入门套件
    • 示例
    • 人工智能
    • 程序集
    • Assets
    • 认证授权
    • Blazor
    • 区块链
    • 书籍
    • 自动构建
    • 报表
    • 缓存
    • 日历
    • 聊天
    • CLI
    • CLR
    • CMS
    • 代码分析和指标
    • 代码片段
    • 压缩
    • 持续集成
    • 密码学
    • 数据库
    • 数据库驱动
    • 日期时间
    • 反编译
    • 部署
    • DirectX
    • 分布式计算
    • DLR
    • 文档
    • 电商支付
    • 模拟器
    • 环境管理
    • ETL
    • 事件消息
    • Exception
    • 扩展
    • 函数式编程
    • 游戏引擎
    • GIS
    • Git工具
    • 绘图
    • GraphQL
    • GUI
    • HTML-CSS
    • HTTP
    • IDE
    • 图片处理
    • 安装工具
    • 交互式编程
    • 国际化
    • 互操作性
    • IoC
    • JS引擎
    • 日志
    • 机器学习和数据科学
    • Markdown
    • 邮件
    • 数学
    • 媒体
    • 指标
    • 微型框架
    • 最小化器
    • MVVM
    • 网络
    • 对象映射
    • Office
    • OpenAI
    • ORM
    • 包管理器
    • PDF
    • 性能分析工具
    • 协议
    • 推送通知
    • SQL构建器
    • 消息队列
    • RPC
    • 响应式编程
    • 实时通信
    • 正则表达式
    • 任务调度
    • SDK和API
    • 搜索引擎
    • 序列化
    • SMS
    • 状态机
    • 静态站点生成
    • 强命名
    • 风格指南
    • 模板引擎
    • 测试
    • 工具
    • 交易
    • UI自动测试
    • Visual Studio 插件
    • Web浏览器
    • Web框架
    • WebServers
    • WebSocket
    • Windows服务
    • WPF
    • 解析器
    • 源码生成
    • 其他
    • 资源
  • AspNetCore面试题
  • Elasticsearch面试题
  • MongoDB面试题
  • MySql面试题
  • Nginx面试题
  • RabbitMQ面试题
  • Redis面试题
  • 设计模式
  • 微服务
🧑‍💻.NET Blog
GitHub (opens new window)
npm
  • 简介
  • ORM

    • EFCore
    • Dapper
    • FreeSql
    • SqlSugar
  • 任务调度

    • Hangfire
    • Quartz
    • FluentScheduler
    • Coravel
    • Quartzmin
  • 日志

    • Serilog
    • NLog
    • Log4Net
    • Stackdriver
    • ExceptionLess
  • 身份认证与授权

    • IdentityServer4
    • Identity
    • JWTBearer
    • Auth0
    • OpenIddict
  • Swagger文档

    • Swagger
    • Swashbuckle
    • NSwag
    • ReDoc
  • 对象映射

    • AutoMapper
    • EmitMapper
    • AgileMapper
    • Mapster
      • 安装
      • 基本使用
      • 自定义映射
      • 集合映射
        • 集合映射
        • 集合元素映射
      • 高级用法
        • 构造函数注入
        • 委托
        • 缓存
      • 总结
  • 消息传递

    • MediatR
    • MassTransit
    • Rebus
    • NServiceBus
  • 熔断重试限流

    • Polly
    • Resilience4j
    • AkkaNET
  • 缓存

    • CsRedis
    • FreeRedis
    • EasyCaching
    • StackExchangeRedis
    • CacheCow
    • NCache
    • Memory
  • 注册发现

    • Consul
    • Nacos
    • Apollo
  • 网关

    • Ocelot
    • Kong
    • Traefik
    • Zuul
  • GraphQL

    • GraphQLPlatform
    • GraphQLdotnet
  • 更多

    • NodaTime
    • FluentAssertions
    • Humanizer
    • 爬虫-AngleSharp
    • 邮件-MailKit
  • NET微服务
  • 对象映射
一个大西瓜
2023-04-20
目录

Mapster

开源地址

Github:https://github.com/MapsterMapper/Mapster (opens new window)

Mapster是一种.NET库,用于将一种类型映射到另一种类型。它使得对象之间的映射变得非常容易,而且速度很快。本文将介绍如何在.NET中使用Mapster来实现对象之间的映射。

# 安装

Mapster可以通过NuGet进行安装。在Visual Studio中,右键单击项目并选择“管理NuGet程序包”菜单项。在NuGet窗口中搜索“Mapster”并安装它。安装完成后,就可以开始使用Mapster了。

# 基本使用

以下是一个简单的示例,展示如何使用Mapster将一个类型映射到另一个类型。


using Mapster;

public class Source
{
    public int Id { get; set; }
    public string Name { get; set; }
}

public class Destination
{
    public int Id { get; set; }
    public string Name { get; set; }
}

var source = new Source { Id = 1, Name = "Mapster" };
var destination = source.Adapt<Destination>();

在这个示例中,我们定义了两个类:Source和Destination。我们创建了一个Source实例,并使用Adapt方法将其映射到一个Destination实例。Mapster会自动将源对象的属性值赋值给目标对象的相应属性。在这个例子中,源对象的Id和Name属性被映射到目标对象的Id和Name属性。

# 自定义映射

有时候我们需要更复杂的映射,例如在源对象和目标对象之间存在一些不同的属性名称,或者需要进行一些转换才能进行映射。Mapster允许我们通过创建一个映射配置来实现自定义映射。

以下是一个示例,展示如何使用Mapster进行自定义映射。


using Mapster;

public class Source
{
    public int Id { get; set; }
    public string Name { get; set; }
    public int Age { get; set; }
}

public class Destination
{
    public int Id { get; set; }
    public string FullName { get; set; }
    public int YearsOld { get; set; }
}

var source = new Source { Id = 1, Name = "Mapster", Age = 20 };

var destination = source.Adapt<Destination>(config =>
{
    config
        .Map(dest => dest.FullName, src => $"{src.Name} ({src.Age})")
        .Map(dest => dest.YearsOld, src => src.Age);
});

在这个示例中,我们定义了一个源对象和一个目标对象。我们使用Adapt方法将源对象映射到目标对象,并使用配置对象进行自定义映射。在配置对象中,我们使用Map方法将源对象的Name和Age属性映射到目标对象的FullName和YearsOld属性。在FullName属性映射中,我们使用了一个lambda表达式来将源对象的Name和Age属性组合成FullName属性。

# 集合映射

让我们继续介绍Mapster在集合映射方面的功能。

# 集合映射

以下是一个示例,展示如何使用Mapster进行集合映射。


using Mapster;

public class SourceItem
{
    public int Id { get; set; }
    public string Name { get; set; }
}

public class DestinationItem
{
    public int Id { get; set; }
    public string Name { get; set; }
}

public class Source
{
    public List<SourceItem> Items { get; set; }
}

public class Destination
{
    public List<DestinationItem> Items { get; set; }
}

var source = new Source
{
    Items = new List<SourceItem>
    {
        new SourceItem { Id = 1, Name = "Item 1" },
        new SourceItem { Id = 2, Name = "Item 2" },
        new SourceItem { Id = 3, Name = "Item 3" }
    }
};

var destination = source.Adapt<Destination>(config =>
{
    config.Map(dest => dest.Items, src => src.Items);
});

在这个示例中,我们定义了两个类:SourceItem和DestinationItem表示源对象和目标对象的一个项。我们还定义了包含项列表的Source和Destination类。我们创建了一个Source实例,其中包含三个SourceItem项。我们使用Adapt方法将源对象映射到目标对象,并使用配置对象进行集合映射。在配置对象中,我们使用Map方法将源对象的Items列表映射到目标对象的Items列表。

# 集合元素映射

以下是一个示例,展示如何使用Mapster进行集合元素映射。


using Mapster;

public class SourceItem
{
    public int Id { get; set; }
    public string Name { get; set; }
}

public class DestinationItem
{
    public int Id { get; set; }
    public string FullName { get; set; }
}

public class Source
{
    public List<SourceItem> Items { get; set; }
}

public class Destination
{
    public List<DestinationItem> Items { get; set; }
}

var source = new Source
{
    Items = new List<SourceItem>
    {
        new SourceItem { Id = 1, Name = "Item 1" },
        new SourceItem { Id = 2, Name = "Item 2" },
        new SourceItem { Id = 3, Name = "Item 3" }
    }
};

var destination = source.Adapt<Destination>(config =>
{
    config.NewConfig<SourceItem, DestinationItem>()
        .Map(dest => dest.FullName, src => $"Item {src.Id}: {src.Name}");

    config.Map(dest => dest.Items, src => src.Items);
});

在这个示例中,我们定义了两个类:SourceItem和DestinationItem。我们还定义了包含项列表的Source和Destination类。我们创建了一个Source实例,其中包含三个SourceItem项。我们使用Adapt方法将源对象映射到目标对象,并使用配置对象进行集合元素映射。在配置对象中,我们使用NewConfig方法创建一个新的映射配置,将源对象的Id和Name属性映射到目标对象的FullName属性。

# 高级用法

Mapster还提供了一些高级用法,例如:

# 构造函数注入

如果目标对象的构造函数需要依赖于其他对象,则可以使用Mapster的构造函数注入功能来实现。

以下是一个示例,展示如何使用构造函数注入功能。


using Mapster;

public class Source
{
    public int Id { get; set; }
    public string Name { get; set; }
}

public class Destination
{
    private readonly ILogger _logger;

    public Destination(ILogger logger)
    {
        _logger = logger;
    }

    public int Id { get; set; }
    public string Name { get; set; }
}

var source = new Source { Id = 1, Name = "Mapster" };

var destination = source.Adapt<Destination>(config =>
{
    config.ConstructUsing(() => new Destination(new ConsoleLogger()));
});

在这个示例中,我们定义了一个Source和Destination类。我们创建了一个Source实例,并使用Adapt方法将其映射到一个Destination实例。在配置对象中,我们使用ConstructUsing方法指定了一个构造函数来创建Destination实例,并将ILogger对象注入其中。

# 委托

Mapster允许使用委托来实现更高级的映射操作。

以下是一个示例,展示如何使用Mapster的委托功能。


using Mapster;

public class Source
{
    public int Id { get; set; }
    public string Name { get; set; }
    public int Age { get; set; }
}

public class Destination
{
    public int Id { get; set; }
    public string FullName { get; set; }
    public int YearsOld { get; set; }
}

var source = new Source { Id = 1, Name = "Mapster", Age = 20 };

var destination = source.Adapt<Destination>(config =>
{
    config
        .Map(dest => dest.FullName, src => $"{src.Name} ({src.Age})")
        .Map(dest => dest.YearsOld, src => src.Age)
        .After((src, dest) =>
        {
            if (dest.YearsOld < 18)
            {
                dest.FullName = $"{dest.FullName} (Minor)";
            }
        });
});

在这个示例中,我们定义了一个Source和Destination类。我们创建了一个Source实例,并使用Adapt方法将其映射到一个Destination实例。在配置对象中,我们使用Map方法将源对象的Name和Age属性映射到目标对象的FullName和YearsOld属性,并使用After方法指定了一个委托,该委托将在映射完成后执行。在这个委托中,我们检查YearsOld属性的值是否小于18,并将FullName属性添加“(Minor)”后缀以表示未成年人。

# 缓存

Mapster还提供了缓存功能,以便重复映射操作更快。

以下是一个示例,展示如何使用Mapster的缓存功能。


using Mapster;

public class Source
{
    public int Id { get; set; }
    public string Name { get; set; }
}

public class Destination
{
    public int Id { get; set; }
    public string Name { get; set; }
}

var source = new Source { Id = 1, Name = "Mapster" };

var config = new TypeAdapterConfig();
config.CacheTo<TypeAdapterConfig>();

var destination1 = source.Adapt<Destination>(config);
var destination2 = source.Adapt<Destination>(config);

Console.WriteLine(destination1 == destination2); // 输出 True

在这个示例中,我们定义了一个Source和Destination类。我们创建了一个TypeAdapterConfig对象,并使用CacheTo方法将其缓存。我们使用Adapt方法两次将源对象映射到目标对象,并比较两个目标对象是否相等。由于缓存功能,两个目标对象应该是同一个实例,因此输出True。

# 总结

在本文中,我们介绍了如何在.NET中使用Mapster来实现对象之间的映射。我们了解了Mapster的基本用法、自定义映射、集合映射、高级用法等功能。使用Mapster可以使对象之间的映射变得非常容易和快速,如果您需要在.NET中进行对象映射操作,那么Mapster是一个不错的选择。

上次更新: 2023/04/26, 22:10:06
AgileMapper
MediatR

← AgileMapper MediatR→

Theme by Vdoing | Copyright © 2019-2024 一个大西瓜 | MIT License | 苏ICP备2023013501号
  • 跟随系统
  • 浅色模式
  • 深色模式
  • 阅读模式