AutoMapper官方文档(十三)【值转换器,Null替换,Map行为前后】

来源:互联网 发布:mysql 建库语句 utf8 编辑:程序博客网 时间:2024/06/12 03:31

值转换器

值转换器对另一种类型应用额外的转换。 在分配值之前,AutoMapper将检查要设置的值是否有任何相关的值转换,并在设置之前应用它们。

您可以创建几个不同级别的值转换器:

    Globally    Profile    Map    Member
Mapper.Initialize(cfg => {    cfg.ValueTransformers.Add<string>(val + "!!!");});var source = new Source { Value = "Hello" };var dest = Mapper.Map<Dest>(source);dest.Value.ShouldBe("Hello!!!");

Null替换

空替换允许您为目标成员提供一个备用值(如果源成员链中的任何位置为null)。 这意味着,不是从null映射,而是从您提供的值映射。

var config = new MapperConfiguration(cfg => cfg.CreateMap<Source, Dest>()    .ForMember(destination => destination.Value, opt => opt.NullSubstitute("Other Value")));var source = new Source { Value = null };var mapper = config.CreateMapper();var dest = mapper.Map<Source, Dest>(source);dest.Value.ShouldEqual("Other Value");source.Value = "Not null";dest = mapper.Map<Source, Dest>(source);dest.Value.ShouldEqual("Not null");

假设替代者是源成员类型,并且会在到达目标类型之后经过任何映射/转换。


Map行为前后

偶尔,您可能需要在映射发生之前或之后执行自定义逻辑。 这应该是一个罕见的事情,因为在AutoMapper之外完成这项工作更为明显。 您可以创建全局映射之前/之后的操作:

Mapper.Initialize(cfg => {  cfg.CreateMap<Source, Dest>()    .BeforeMap((src, dest) => src.Value = src.Value + 10)    .AfterMap((src, dest) => dest.Name = "John");});

或者,您可以在映射期间创建映射之前/之后的回调:

int i = 10;Mapper.Map<Source, Dest>(src, opt => {    opt.BeforeMap((src, dest) => src.Value = src.Value + i);    opt.AfterMap((src, dest) => dest.Name = HttpContext.Current.Identity.Name);});

当您需要映射操作之前/之后的上下文信息时,后一种配置很有用。