Auto Mapper03
经过上一篇博客的学习,大体了解了Auto Mapper的运行机制和操作流程。我们下来学习下,AutoMapper里面具体的一些东西。
一:规则
当我们使用AutoMapper创建实体和外部Model的映射的时候,AutoMapper的匹配原值有三种方式。
#:名称相同的属性进行映射,不区分大小写。
#:带Get前缀的方法进行映射。<例子(Order和OrderDto):Order中的GetTotal分割成Get和Total,Total会和Dto中的进行匹配。>
#:目标类型属性分割。<CustomerName也是一样,是分割的,Name回合后面的匹配。>
Order类
/// <summary>
/// 订单
/// </summary>
public class Order
{
public Customer Customer { get; set; } public decimal GetTotal()
{
return 10*10;
}
}
/// <summary>
/// 顾客
/// </summary>
public class Customer
{
public string Name { get; set; }
}
OrderDto类
/// <summary>
/// 数据传输对象Dto
/// </summary>
public class OrderDto
{
public string CustomerName { get; set; }
public decimal Total { get; set; }
}
这里我们将Order转换为OrderDto,也就是Order里面的Customer中的Name转换为CustomerName;
Order dto=new Order()
{
Customer = new Customer{Name = "ahui"},
};
//配置
Mapper.CreateMap<Order, OrderDto>();
//执行
var order = Mapper.Map<Order,OrderDto>(dto);
Console.WriteLine(order.CustomerName);
Console.ReadKey();

二:AutoMapper中利用Condition来进行判断,从而选择是否进行转换。
订单
/// <summary>
/// 订单
/// </summary>
public class Order
{
public Order()
{
Number = 100;
}
//订单数量
public int Number { get; set; }
}
订单DTO
/// <summary>
/// 数据传输对象Dto
/// </summary>
public class OrderDto
{
public OrderDto()
{
Num = 90;
}
public int Num { get; set; }
}
Main()方法
//配置 通过Condition来规定Order中的值是0~12之间。在这个之间就可以进行映射,不是就不映射。输出其默认值10;
Mapper.CreateMap<Order,OrderDto>().ForMember(x=>x.Num,mo=>mo.Condition(s=>s.Number >0&& s.Number <12)).ForMember(x=>x.Num,mo=>mo.MapFrom(x=>x.Number));
//执行映射
var orderDto = Mapper.Map<OrderDto>(new Order(){Number = 10});
var p1 = Mapper.Map<OrderDto>(new Order(){Number = 20});
Console.WriteLine(orderDto.Num); //这里输出10
Console.WriteLine(p1.Num); //这里转换失败,结果为90.
Console.ReadKey();
通过Condition这个方法我们可以规定如何去转换,指定转换条件。
三:通过Initialize来增加一个配置文件。
这里增加一个配置文件,主要是防止我们以后配置文件多了,我们不必每一次都写,在需要调用配置文件即可。
1:新建一个ProFilesMapper类继承自Profile,并且实现他的方法Configuer(),这个方法就是我们在里面写配置文件的。
/// <summary>
/// 配置文件
/// </summary>
public class ProFilesMapper:Profile
{
protected override void Configure()
{
//这里放一些CreateMap(),也就是我们之前的配置映射
//配置 通过Condition来规定Order中的值是0~12之间。在这个之间就可以进行映射,不是就不映射。输出其默认值10;
Mapper.CreateMap<Order, OrderDto>().ForMember(x => x.Num, mo => mo.Condition(s => s.Number > 0 && s.Number < 12)).ForMember(x => x.Num, mo => mo.MapFrom(x => x.Number));
}
}
2:在main()方法里面可以直接使用加载配置文件就可以实现之前的的配置了。
//配置
Mapper.Initialize(x =>x.AddProfile<ProFilesMapper>());
这样就可以实现配置了。
//配置
Mapper.Initialize(x =>x.AddProfile<ProFilesMapper>());
//执行映射
var orderDto = Mapper.Map<OrderDto>(new Order() { Number = 10 });
var p1 = Mapper.Map<OrderDto>(new Order() { Number = 20 });
Console.WriteLine(orderDto.Num); //这里输出10
Console.WriteLine(p1.Num); //这里转换失败,结果为90.
Console.ReadKey();
四:实现命名惯例
只需要配置中添加下面两句代码
protected override void Configure()
{
//这里放一些CreateMap(),也就是我们之前的配置映射
//配置 通过Condition来规定Order中的值是0~12之间。在这个之间就可以进行映射,不是就不映射。输出其默认值10;
Mapper.CreateMap<Order, OrderDto>().ForMember(x => x.Num, mo => mo.Condition(s => s.Number > 0 && s.Number < 12)).ForMember(x => x.Num, mo => mo.MapFrom(x => x.Number)); //通过下面的两个设置源和目标的命名惯例 而且必须写在CreateMap后面
SourceMemberNamingConvention=new LowerUnderscoreNamingConvention();
DestinationMemberNamingConvention=new PascalCaseNamingConvention();
}
//配置
Mapper.Initialize(x=>x.AddProfile<ProFilesMapper>());
//执行映射
var d1 = Mapper.Map<OrderDto>(new Order()
{
MyName ="ahui"
});
Console.WriteLine(d1.my_name);
Console.ReadKey();

看下我们的两个属性
public string my_name { get; set; }
public string MyName { get; set; }
这个我觉得就是像忽略了大小写,直接就可以进行映射。
五:集合之间的映射
这里就是在我们Mapper.Map<>(),执行映射的时候,这里我们看他们需要什么类型的,就传递什么。
配置:
Mapper.CreateMap<Souce,Destination>();
类代码:
public class Souce
{
public int Value { get; set; }
} public class Destination
{
public int Value { get; set; }
}
main()方法:
#region 示例08
//配置
Mapper.Initialize(x=>x.AddProfile<ProFilesMapper>());
//初始化,这就是将其初始化为数组
var sources = new[]
{
new Souce(){Value = 1},
new Souce(){Value = 2},
new Souce(){Value = 3},
};
//执行映射
IEnumerable<Destination> iEnumerabledDestinations = Mapper.Map<IEnumerable<Destination>>(sources); ICollection<Destination> iCollectionDestinations = Mapper.Map<ICollection<Destination>>(sources); IList<Destination> iListDest = Mapper.Map<IList<Destination>>(sources); List<Destination> listDests =
Mapper.Map<List<Destination>>(sources); Destination[] deatArrey =
Mapper.Map<Destination[]>(sources); Console.WriteLine("******第一个转换*****");
foreach (var item in iEnumerabledDestinations)
{
Console.WriteLine(item.Value + ",,");
}
Console.WriteLine("******第二个转换*****");
foreach (var item in iCollectionDestinations)
{
Console.WriteLine(item.Value + ",,");
}
Console.WriteLine("******第三个转换*****");
foreach (var item in iListDest)
{
Console.WriteLine(item.Value + ",,");
}
Console.WriteLine("******第四个转换*****");
foreach (var item in deatArrey)
{
Console.WriteLine(item.Value + ",,");
}
Console.ReadKey();

我们通过这四种类型的执行映射都可以得到我们想要的结果,说明AutoMapper是成功的。
附件:
“tkb至简” http://www.cnblogs.com/farb/p/4932692.html
Auto Mapper03的更多相关文章
- C++11特性——变量部分(using类型别名、constexpr常量表达式、auto类型推断、nullptr空指针等)
#include <iostream> using namespace std; int main() { using cullptr = const unsigned long long ...
- overflow:hidden与margin:0 auto之间的冲突
相对于父容器水平居中的代码margin:0 auto与overflow:hidden之间存在冲突.当这两个属性同时应用在一个DIV上时,在chrome浏览器中将无法居中.至于为啥我也不明白.
- Android Auto开发之一《开始学习Auto 》
共同学习,共同进步, 转载请注明出处.欢迎微信交流:sfssqs,申请注明"Android Car"字样 ================= =================== ...
- width:100%;与width:auto;的区别
<div> <p>1111</p> </div> div{ width:980px; background-color: #ccc; height:30 ...
- SQl 2005 For XMl 简单查询(Raw,Auto,Path模式)(1)
很多人对Xpath可能比较熟悉,但不知道有没有直接操作过数据库,我们都知道 在Sql2005里公支持的几种查询有Raw,Auto模式,页并没有Path和Elements用法等,如果在2000里使用过 ...
- margin:0 auto;不居中
margin:0 auto:不居中可能有以下两个的原因; 1.没有设置宽度<div style="margin:0 auto;"></div>看看上面的代码 ...
- 初学C++ 之 auto关键字(IDE:VS2013)
/*使用auto关键字,需要先赋初值,auto关键字是会根据初值来判断类型*/ auto i = ; auto j = ; cout << "auto i = 5" & ...
- C++11 - 类型推导auto关键字
在C++11中,auto关键字被作为类型自动类型推导关键字 (1)基本用法 C++98:类型 变量名 = 初值; int i = 10; C++11:auto 变量名 = 初值; auto i ...
- 为什么 "auto a = 1;" 在C语言中可以编译通过?
参照:这里 这让我想起之前看的一部书, int i; 其实是等价与 auto int i; 表示为局部变量 这应该与static是相对的吧?
随机推荐
- ubuntu笔记
安装包 sudo dpkg -i xxxx.deb 如果用户具有sudo权限,那么直接可以运行如下命令: #sudo su root #passwd #更改密码 或者直接运行sudo passwd r ...
- Hadoop笔记
教程: Elasticsearch.MongoDB和Hadoop比较: http://blog.csdn.net/hong0220/article/details/47631409
- android知识杂记(三)
记录项目中的android零碎知识点,用以备忘. 1.android 自定义权限 app可以自定义属于自己的权限: <permission android:description="s ...
- Aoite 系列(01) - 比 Dapper 更好用的 ORM
Aoite 是一个适于任何 .Net Framework 4.0+ 项目的快速开发整体解决方案.Aoite.Data 适用于市面上大多数的数据库提供程序,通过统一封装,可以在日常开发中简单便捷的操作数 ...
- Silverlight无法启动调试,错误“Unable to start debugging. The Silverlight Developer Runtime is not installed. Please install a matching version.” 解决办法
今天调试Silverlight出现了以下错误: 意思是“无法启动调试,因为Silverlight Developer Runtime没有安装,请安装一个匹配的版本”.但是按Ctrl + F5可以调试运 ...
- leveldb源码学习系列
楼主从2014年7月份开始学习<>,由于书籍比较抽象,为了加深思考,同时开始了Google leveldb的源码学习,主要是想学习leveldb的设计思想和Google的C++编程规范.目 ...
- [ZigBee] 9、ZigBee之AD剖析——AD采集CC2530温度串口显示
1.ADC 简介 ADC 支持多达14 位的模拟数字转换,具有多达12 位有效数字位.它包括一个模拟多路转换器,具有多达8 个各自可配置的通道:以及一个参考电压发生器.转换结果通过DMA 写入存储器. ...
- FastUI快速界面原型制作工具
FastUI是一款快速制作应用程序界面原型的小工具,它之所以快,是因为它体积小巧.功能简洁实用. 在真正的应用程序(包括winform.手机app.网站等)开始编码之前,一般要先设计出原型,以便确认需 ...
- Entity Framework中IQueryable, IEnumerable, IList的区别
博客园里有这样的总结.这里姑且先列个题目, 提醒自己记忆.
- CentOS6.5下安装JDK
之前一直没有完全的总结出一篇关于Linux下安装Java的过程,今天正好就整理下. 下载jdk 如果在官网下载比较慢,那么可以到我的云盘分享上,下载jdk 1.8.0的版本: 下载地址参考链接 解压缩 ...
