本篇AutoMapper使用场景:

※ 类型转换,源string类型分别转换成int, DateTime,Type

※ 源和目标都包含复杂类型属性

※ 把源中的一个属性映射到目标中的多个属性

类型转换,源string类型分别转换成int, DateTime,Type

□ Domain model

public class Source2

{

public string Value1 { get; set; }

public string Value2 { get; set; }

public string Value3 { get; set; }

}

□ View model

public class Destination2

{

public int Value1 { get; set; }

public DateTime Value2 { get; set; }

public Type Value3 { get; set; }

}

□ 派生TypeConverter<,>自定义转换

//string转换成DateTime类型

public class DateTimeTypeConverter : TypeConverter<string,DateTime>

{

protected override DateTime ConvertCore(string source)

{

return System.Convert.ToDateTime(source);

}

}

//string转换成Type类型

//当然,这里的string必须是当前项目下的某个类

public class TypeTypeConverter : TypeConverter<string, Type>

{

protected override Type ConvertCore(string source)

{

Type type = Assembly.GetExecutingAssembly().GetType(source);

return type;

}

}

□ 映射配置

Mapper.CreateMap<string, int>().ConvertUsing(Convert.ToInt32);

Mapper.CreateMap<string, DateTime>().ConvertUsing<DateTimeTypeConverter>();

Mapper.CreateMap<string,Type>().ConvertUsing<TypeTypeConverter>();

Mapper.CreateMap<Source2, Destination2>();

□ 要点

类型转换用Convertusing<>()方法

源和目标都包含复杂类型属性

□ Domain model

public class OuterSource

{

public int Value { get; set; }

public InnerSource Inner { get; set; }

}

public class InnerSource

{

public int OtherValue { get; set; }

}

□ View model

public class OuterDest

{

public int Value { get; set; }

public InnerDest Inner { get; set; }

}

public class InnerDest

{

public int OtherValue { get; set; }

}

□ 映射配置

Mapper.CreateMap<OuterSource, OuterDest>();

Mapper.CreateMap<InnerSource, InnerDest>();

□ 使用

public ActionResult Nest()

{

var source = new OuterSource()

{

Value = 5,

Inner = new InnerSource(){OtherValue = 15}

};

var dest = Mapper.Map<OuterSource, OuterDest>(source);

return View(dest);

}

□ 要点

当源和目标都具有复杂属性并对应,复杂属性对应的类也需要配置映射。

把源中的一个属性映射到目标中的多个属性

□ Domain model

public class CalendarEvent

{

public DateTime EventDate { get; set; }

public string Title { get; set; }

}

public class CalendarEventForm

{

public DateTime EventDate { get; set; }

public int EventHour { get; set; }

public int EventMinute { get; set; }

public string Title { get; set; }

}

□ 自定义解析器

//转换成DateTime.Date

public class DateTimeToDateResolver : ValueResolver<CalendarEvent, DateTime>

{

protected override DateTime ResolveCore(CalendarEvent source)

{

return source.EventDate.Date;

}

}

//转换成DateTime.Hour

public class DateTimeToHourResolver : ValueResolver<CalendarEvent, int>

{

protected override int ResolveCore(CalendarEvent source)

{

return source.EventDate.Hour;

}

}

//转换成DateTime.Minute

public class DateTimeToMinuteResolver : ValueResolver<CalendarEvent, int>

{

protected override int ResolveCore(CalendarEvent source)

{

return source.EventDate.Minute;

}

}

□ 映射配置

Mapper.CreateMap<CalendarEvent, CalendarEventForm>()

.ForMember("EventDate", opt => opt.ResolveUsing<DateTimeToDateResolver>())

.ForMember("EventHour", opt => opt.ResolveUsing<DateTimeToHourResolver>())

.ForMember("EventMinute", opt => opt.ResolveUsing<DateTimeToHourResolver>());

□ 使用

public ActionResult Projection()

{

var calendarEvent = new CalendarEvent

{

EventDate = new DateTime(2008, 12, 15, 20, 30, 0),

Title = "Company Holiday Party"

};

CalendarEventForm from = Mapper.Map<CalendarEvent, CalendarEventForm>(calendarEvent);

return View(from);

}

AutoMapper在MVC中的运用04-string映射各种类型、一个属性映射多个属性等的更多相关文章

  1. AutoMapper在MVC中的运用01-配置、使用、单元测试、举例

    MVC中,如果想在Domain Model和View Model之间建立映射,用AutoMapper是一个不错的选择.不仅如此,AutoMapper能在不同对象之间建立映射,比如string与int类 ...

  2. Taurus.MVC WebAPI 入门开发教程3:路由类型和路由映射。

    系列目录 1.Taurus.MVC WebAPI  入门开发教程1:框架下载环境配置与运行. 2.Taurus.MVC WebAPI 入门开发教程2:添加控制器输出Hello World. 3.Tau ...

  3. AutoMapper在MVC中的运用02-Decimal转String、集合、子父类映射

    本篇AutoMapper使用场景: ※ Decimal转换成String类型 ※ 源数组转换成目标数组 ※ 源中的集合(数组)属性转换成目标中的集合(数组)属性 ※ 子类父类间的映射 Decimal转 ...

  4. AutoMapper在MVC中的运用07-映射在订单场景的例子

    本文参考了Taswar Bhatti的博客,他写了<Instant AutoMapper>这本书.遗憾的是,这本电子版书在国内还买不到,也下载不到.也只能从他的有限几篇博文中来窥探一二了. ...

  5. AutoMapper在MVC中的运用05-映射中的忽略、处理null、多种映射转换

    本篇AutoMapper使用场景: ※ 动态实现接口方法或属性 ※ 目标中的属性如果比源多,可以忽略多出的属性 ※ 目标有virtual属性,可忽略 ※ 目标属性值为null的解决办法 ※ int转s ...

  6. AutoMapper在MVC中的运用03-字典集合、枚举映射,自定义解析器

    本篇AutoMapper使用场景: ※ 源字典集合转换成目标字典集合 ※ 枚举映射 ※ 自定义解析器 ※ 源中的复杂属性和Get...方法转换成目标属性 源字典集合转换成目标字典集合 □ Domain ...

  7. AutoMapper在MVC中的运用小结

    配置.单元测试.AOP注入 Decimal转换成String类型 源数组转换成目标数组 源中的集合(数组)属性转换成目标中的集合(数组)属性 子类父类间的映射 源字典集合转换成目标字典集合 枚举映射 ...

  8. AutoMapper在MVC中的运用06-一次性定义映射、复杂类型属性映射

    本篇AutoMapper使用场景: ※ 当源和目标具有同名的复杂类型属性.集合类型属性,这2种属性对应的类间也需建立映射 ※ 一次性定义好源和目标的所有映射 ※ 一次性定义好源和目标的所有映射,目标中 ...

  9. C++ Primer学习笔记2--c++标准库中的 vector、string 和 bitset 类型

    一.string    #include <string>  using std::string    初始化函数:    string s1;        默认构造函数 s1 为空串 ...

随机推荐

  1. ispoweroftwo 判断2的次幂【转】

    转自:https://www.cnblogs.com/troublelost/p/5236391.html 首先结果是: public bool IsPowerOfTwo(int n) { if(n& ...

  2. request_irq与request_threaded_irq

    /* * Allocate the IRQ */ #if 0 retval = request_irq(uap->port.irq, pl011_int, 0, "uart-pl011 ...

  3. WPF的EventAggregator的发布和订阅

    EventAggregator是Prism中专门处理ViewModel与ViewModel之间事件传递的类对象,它提供了针对事件的发布方法和订阅方法,所以可以非常方便的来管理事件.下面分几步来实现相关 ...

  4. WPF 中定时器的使用

    DispatcherTimer timer; private void Window_Loaded(object sender, RoutedEventArgs e) { timer = new Di ...

  5. (转)javascript方法--bind()

    地址:https://www.cnblogs.com/xxxxBW/p/4914567.html bind方法,顾名思义,就是绑定的意思,到底是怎么绑定然后怎么用呢,下面就来说说我对这个方法的理解. ...

  6. P1270 【“访问”美术馆】

    $\large{\text{一千个Oier程序中有一千种树形DP}}$ 思路都差不多的,但是每个人都有自己的状态定义与转移 不妨定义$dp[i][j]$表示,在$i$子树内,偷$j$张画,且不考虑根到 ...

  7. SqlServer中查看索引的使用情况

    --查看数据库索引的使用情况 select db_name(database_id) as N'TOPK_TO_DEV', --库名 object_name(a.object_id) as N'Top ...

  8. Java编程的逻辑 (34) - 随机

    本系列文章经补充和完善,已修订整理成书<Java编程的逻辑>,由机械工业出版社华章分社出版,于2018年1月上市热销,读者好评如潮!各大网店和书店有售,欢迎购买,京东自营链接:http:/ ...

  9. NET定时任务组件Hangfire

    开源的.NET定时任务组件Hangfire解析 项目慢慢就要开工了,很多园友都在问这个事情,看来大伙对这事很上心啊,事情需要一步步的来,尽量写出一个我们都满意的项目.以前每次在博客前面都会扯淡一下,不 ...

  10. Linux命令执行顺序— ||和&&和; 比较

    Linux命令执行顺序— ||和&&和; command1 && command2: &&左边的command1执行成功(返回0表示成功)后,& ...