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是相对的吧?
随机推荐
- comet在asp.net中的实现
网上有关“服务器推送”的介绍非常多,其中一种实现方式就是采用comet技术,在浏览器与服务端之间建立一个http协议的“长连接”,所谓“长连接”,就是指浏览器到服务端的http请求不会马上得到服务端的 ...
- [翻译]docker生态圈Mindmap
Docker是一个开源的Linux容器,其被业界所接受,很快成为了一个产业标准.Docker可以减少应用程序启动 时候的大量资源的筹备.docker很快的成为了新兴的应用程序容器标准.现在有很多项目正 ...
- java提高篇(二三)-----HashMap
HashMap也是我们使用非常多的Collection,它是基于哈希表的 Map 接口的实现,以key-value的形式存在.在HashMap中,key-value总是会当做一个整体来处理,系统会根据 ...
- AWS系列之一 亚马逊云服务概述
云计算经过这几年的发展,已经不再是是一个高大上的名词,而是已经应用到寻常百姓家的技术.每天如果你和互联网打交道,那么或多或少都会和云扯上关系.gmail.github.各种网盘.GAE.heroku等 ...
- iOS instruments trace文件解析方案
前言 已很少写文章,不过这次感觉有必要写一下.因为: 1. 这个方案通过debug逆向得来,很有参考意义. 2. iOS这方面资料非常少,做这块时,无论国内外,翻遍了google,baidu都没太多合 ...
- 博文写作——摘要&摘要图标
问题描述: 写博文的时候,一个比较好的习惯就是在博文的开头用简短的文字介绍一下本篇博文的大致内容.在博客园系统里面,如果博文没有在指定的地方添加摘要内容,那么系统会自动截取博文的开始部分作为摘要.如下 ...
- CSS的两个小知识点 伪类选择器和display:table-cell
li:first-child {color:red} li:nth-child(3n) {color: red} 在对nth-child传参的时候,已经直接用公式,3n就表示3的倍数.多用伪类和伪元素 ...
- fir.im Weekly - 2016 开年技术干货分享
开年上班,北上广的技术er 陆续重返"人间".看到别人已返工写代码,竟然有种慌慌的感觉(ง •̀_•́)ง 勤奋好学如你,fir.im weekly 送上最新一波技术分享供你 &q ...
- Chrome同步最新host文件IP列表
使用Chrome的童靴是不是很多都碰到同步问题呢?网上查来查去的都是给些host文件的修改,可是都是几年前的东西,地址都不对了,想想还是自己找到需要解析的域名的IP地址吧 步骤: 1.DNS设置为8. ...
- dubbo+zookeeper简单环境搭建
dubbo+zoopeeper例子 [TOC] 标签(空格分隔): 分布式 dubbo dubbo相关 dubbo是目前国内比较流行的一种分布式服务治理方案.还有一种就是esb了.一般采用的是基于Ap ...
