什麼是AutoMapper?數組
在多層結構中,常常用到對象到對象的轉化,手工去寫複製太過麻煩。而AutoMapper就是一個能夠實現自動轉換的類庫。 它提供了一些有趣的約定,從而弄清楚如何將類型A映射到類型B.只要類型B遵循AutoMapper創建的約定,映射兩種類型幾乎就是零配置。
app
使用Nuget 直接引用AutoMapper就能夠使用AutoMapper了。spa
private static volatile MapperTool mapper = null; private static object syncRoot = new Object(); public static readonly List<Type> typeList = null; /// <summary> /// 註冊須要轉換的類型 /// </summary> private MapperTool() { Mapper.Initialize(cfg => { //指定不一樣屬性映射demo //cfg.CreateMap<auth_userVo, t_auth_user>() // .ReverseMap() // .ForMember(dest => dest.id, opt => opt.MapFrom(src => src.rid)) // .ForMember(dest => dest.update, opt => opt.MapFrom(src => src.create)); cfg.CreateMap<t_auth_rules, auth_rulesDto>().ReverseMap(); cfg.CreateMap<UserListPo, UserListVo>() .ForMember(dest => dest.Address, opt => opt.MapFrom(src => src.City + src.Address)).ReverseMap();
//設置反向映射ReverseMap()
//字段類型不太一致的,可是有規律的 徹底能夠自動實現轉化 不須要在這裏設置(若是是list數組必須建立CreateMap)
//類型不一致,名稱不符合約定的就須要使用MapFrom 來指定 也能夠再內部加入簡單的邏輯運算 如兩個字段值合併成新的字段ForMember(dest => dest.Address, opt => opt.MapFrom(src => src.City + src.Address))) })
//驗證是否全部字段都轉換了 //Mapper.Configuration.AssertConfigurationIsValid(); }
private MapperTool(List<Type[]> TypeList) { Mapper.Initialize(cfg => { foreach (var type in TypeList) { cfg.CreateMap(type[0], type[1]).ReverseMap();}
});
}
/// <summary>
/// 初始化註冊Mapper
/// </summary>
public static MapperTool Instance { get { if (mapper == null) { lock (syncRoot) { if (mapper == null) { mapper = new MapperTool(); } } } return mapper; } }
/// <summary>
/// 傳入須要轉換的對象
/// </summary>
/// <typeparam name="F">須要轉換的對象類型</typeparam>
/// <typeparam name="T">轉換目標對象類型</typeparam>
/// <param name="f">須要轉換的對象</param>
/// <returns>目標對象</returns>
public T Map<F, T>(F f) where F : new() where T : new() { return Mapper.Map<F, T>(f); }
對象互轉:code
UserListVo uv= MapperTool.Instance.Map<UserListPo, UserListVo>(new UserListPo())對象
集合互轉:blog
List<UserListVo> uvs= MapperTool.Instance.Map<List<UserListPo>, List<UserListVo>>(new List<UserListPo>())get