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
目录

AgileMapper

开源地址

Github:https://github.com/AgileObjects/AgileMapper (opens new window)

AgileMapper 是一个用于 .NET 的开源对象映射库,它提供了一种简单、灵活、强大的方式来处理对象映射。本文将为你介绍 AgileMapper 的使用方法,并提供详细的示例。

# 安装

你可以通过 NuGet 包管理器来安装 AgileMapper,也可以手动下载并添加到你的项目中。

在 NuGet 包管理器控制台中运行以下命令来安装 AgileMapper:


Install-Package AgileObjects.AgileMapper

# 基本用法

在开始使用 AgileMapper 之前,你需要引用 AgileObjects.AgileMapper 命名空间。

下面是一个简单的示例,用于将一个 Person 对象映射到一个 PersonViewModel 对象:


using AgileObjects.AgileMapper;

var person = new Person
{
    FirstName = "John",
    LastName = "Doe",
    Age = 30
};

var viewModel = Mapper.Map(person).ToANew<PersonViewModel>();

这里,我们使用 Mapper 类的 Map 方法来指定源对象 person,并使用 ToANew 泛型方法来指定目标对象的类型 PersonViewModel。最终,viewModel 对象将会包含源对象 person 中的所有属性。

# 配置映射

在某些情况下,你可能需要显式地配置对象映射。例如,当源类型和目标类型的属性名称不匹配时,你需要告诉 AgileMapper 如何映射它们。

下面是一个示例,展示了如何使用 Mapper.WhenMapping 方法来配置映射:


using AgileObjects.AgileMapper;

var person = new Person
{
    FirstName = "John",
    LastName = "Doe",
    Age = 30
};

var viewModel = Mapper
    .WhenMapping
    .From<Person>()
    .To<PersonViewModel>()
    .Map(dest => dest.FullName)
    .To(src => $"{src.FirstName} {src.LastName}")
    .Map(dest => dest.YearsOld)
    .To(src => src.Age)
    .Map(dest => dest.IsAdult)
    .To(src => src.Age >= 18)
    .Map(dest => dest.AgeGroup)
    .To(ctx => ctx.Source.Age < 18 ? "Underage" : "Adult")
    .Map(dest => dest.DateOfBirth)
    .To(src => DateTime.Now.AddYears(-src.Age))
    .Map(dest => dest.Address)
    .To(src => $"{src.AddressLine1}, {src.City}, {src.State} {src.ZipCode}")
    .Map(dest => dest.Country)
    .To(ctx => ctx.Source.Country.ToUpper())
    .ToANew<PersonViewModel>();

在这个示例中,我们首先使用 WhenMapping 方法来指定源类型和目标类型。接着,我们使用 Map 方法来配置属性映射。

在这个示例中,我们将 FullName 属性映射到源类型的 FirstName 和 LastName 属性的组合字符串。我们还将 YearsOld 属性映射到源类型的 Age 属性,IsAdult 属性映射到 Age 属性是否大于等于 18,AgeGroup 属性映射到年龄是否小于 18,DateOfBirth 属性映射到当前时间减去 Age 年后的日期,Address 属性映射到地址的格式化字符串,Country 属性映射到源类型的 Country 属性的大写形式。

# 自定义映射

在某些情况下,你可能需要自定义对象的映射方式。例如,当源类型和目标类型之间存在复杂的转换逻辑时,你需要自定义映射方法。

下面是一个示例,展示了如何使用 Mapper.WhenMapping 方法来自定义映射方法:


using AgileObjects.AgileMapper;

public class Person
{
    public string FirstName { get; set; }
    public string LastName { get; set; }
    public DateTime DateOfBirth { get; set; }
}

public class PersonViewModel
{
    public string FullName { get; set; }
    public int Age { get; set; }
}

var person = new Person
{
    FirstName = "John",
    LastName = "Doe",
    DateOfBirth = new DateTime(1990, 1, 1)
};

var viewModel = Mapper
    .WhenMapping
    .From<Person>()
    .To<PersonViewModel>()
    .Map(ctx => ctx.Source.FirstName + " " + ctx.Source.LastName)
    .To(dest => dest.FullName)
    .Map(ctx => DateTime.Now.Year - ctx.Source.DateOfBirth.Year)
    .To(dest => dest.Age)
    .ToANew<PersonViewModel>();

在这个示例中,我们首先使用 WhenMapping 方法来指定源类型和目标类型。接着,我们使用 Map 方法来自定义映射方法。

在这个示例中,我们将 FullName 属性映射到源类型的 FirstName 和 LastName 属性的组合字符串。我们还将 Age 属性映射到当前年份减去 DateOfBirth 属性的年份后的结果。

# 忽略属性

在某些情况下,你可能需要忽略对象的某些属性。例如,当你不希望将某些敏感数据映射到目标对象时,你需要忽略这些属性。

下面是一个示例,展示了如何使用 Mapper.WhenMapping 方法来忽略属性:


using AgileObjects.AgileMapper;

public class Person
{
    public string FirstName { get; set; }
    public string LastName { get; set; }
    public string Password { get; set; }
}

public class PersonViewModel
{
    public string FullName { get; set; }
}

var person = new Person
{
    FirstName = "John",
    LastName = "Doe",
    Password = "password"
};

var viewModel = Mapper
    .WhenMapping
    .From<Person>()
    .To<PersonViewModel>()
    .Ignore(dest => dest.FullName)
    .Ignore(dest => dest.Password)
    .ToANew<PersonViewModel>();

在这个示例中,我们首先使用 WhenMapping 方法来指定源类型和目标类型。接着,我们使用 Ignore 方法来忽略属性。

在这个示例中,我们忽略了 PersonViewModel 类型的 FullName 和 Person 类型的 Password 属性。

# 映射集合

AgileMapper 也支持映射集合对象。你可以使用 Mapper.Map 方法映射单个对象,也可以使用 Mapper.Map 方法的重载版本来映射集合对象。

下面是一个示例,展示了如何使用 Mapper.Map 方法来映射集合对象:


using AgileObjects.AgileMapper;

public class Person
{
    public string FirstName { get; set; }
    public string LastName { get; set; }
}

public class PersonViewModel
{
    public string FullName { get; set; }
}

var persons = new List<Person>
{
    new Person { FirstName = "John", LastName = "Doe" },
    new Person { FirstName = "Jane", LastName = "Doe" }
};

var viewModels = Mapper
    .Map(persons)
    .ToANew<List<PersonViewModel>>();

在这个示例中,我们首先创建了一个 Person 类型的列表对象 persons,其中包含两个 Person 对象。接着,我们使用 Mapper.Map 方法映射整个列表对象,最终得到一个 PersonViewModel 类型的列表对象 viewModels,其中包含映射后的对象。

# 处理空值

在某些情况下,你可能需要处理源对象中的空值。例如,当源对象中的某些属性为 null 时,你需要设置目标对象中相应的属性为默认值或空值。

下面是一个示例,展示了如何使用 Mapper.WhenMapping 方法来处理空值:


using AgileObjects.AgileMapper;

public class Person
{
    public string FirstName { get; set; }
    public string LastName { get; set; }
}

public class PersonViewModel
{
    public string FullName { get; set; }
}

var person = new Person
{
    FirstName = "John",
    LastName = null
};

var viewModel = Mapper
    .WhenMapping
    .From<Person>()
    .To<PersonViewModel>()
    .Map(dest => dest.FullName)
    .To(src => $"{src.FirstName ?? string.Empty} {src.LastName ?? string.Empty}")
    .ToANew<PersonViewModel>();

在这个示例中,我们首先使用 WhenMapping 方法来指定源类型和目标类型。接着,我们使用 Map 方法来处理源对象中的空值。

在这个示例中,我们将 FullName 属性映射到源类型的 FirstName 和 LastName 属性的组合字符串。我们使用 ?? 运算符来检查属性是否为 null,如果是,则返回空字符串。这样,我们就可以防止空值导致的运行时错误。

# 处理异常

在某些情况下,映射过程可能会导致异常。例如,当源对象中的某些属性类型与目标对象中的属性类型不匹配时,映射过程可能会抛出异常。在这种情况下,你可以使用异常处理机制来捕获异常并处理它们。

下面是一个示例,展示了如何使用 Mapper.WhenMapping 方法来处理异常:


using AgileObjects.AgileMapper;

public class Person
{
    public string FirstName { get; set; }
    public string LastName { get; set; }
}

public class PersonViewModel
{
    public int FullName { get; set; }
}

try
{
    var person = new Person
    {
        FirstName = "John",
        LastName = "Doe"
    };

    var viewModel = Mapper
        .WhenMapping
        .From<Person>()
        .To<PersonViewModel>()
        .Map(dest => dest.FullName)
        .To(src => $"{src.FirstName} {src.LastName}")
        .ToANew<PersonViewModel>();
}
catch (MappingException ex)
{
    // 处理异常
}

在这个示例中,我们首先使用 WhenMapping 方法来指定源类型和目标类型。接着,我们使用 Map 方法来配置属性映射。

在这个示例中,我们将 FullName 属性映射到源类型的 FirstName 和 LastName 属性的组合字符串。由于 PersonViewModel 类型的 FullName 属性是一个整数,而我们试图将字符串赋值给它,所以映射过程将会抛出异常。

在异常处理块中,我们可以使用 MappingException 类来捕获异常并处理它们。这样,我们就可以避免映射过程导致的运行时错误。

# 结论

AgileMapper 是一个功能强大的对象映射库,它提供了一种简单、灵活、强大的方式来处理对象映射。在本文中,我们介绍了 AgileMapper 的基本用法,包括配置映射、自定义映射、忽略属性、映射集合、处理空值和处理异常。我们希望这些示例可以帮助你更好地了解 AgileMapper 的使用方法,并能够在实际项目中使用它来简化对象映射过程。

上次更新: 2023/04/26, 22:10:06
EmitMapper
Mapster

← EmitMapper Mapster→

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