AutoMapper的集合转换用起来有点别扭,原因如下图
简单封装一下,使使用体验一致:(相同属性才拷贝)
public class Mapper { /// <summary> /// 对象拷贝(属性相同的字段拷贝,支持不同对象类型) /// </summary> /// <typeparam name="s"></typeparam> /// <typeparam name="d"></typeparam> /// <param name="src">源数据</param> /// <param name="dst">复制到的对象</param> public static void Map<s, d>(s src, ref d dst) where s : class where d : class { var stype = src.GetType(); var isList = stype.IsGenericType && stype.GetGenericTypeDefinition() == typeof(List<>); var isArray = stype.IsArray; var config = new AutoMapper.MapperConfiguration(cfg => cfg.CreateMap<s, d>()); if (isList) {//获得List<T>的元素T类型 config = GetCollectionConfig(stype.GetGenericArguments()[0], dst.GetType().GetGenericArguments()[0]); } if (isArray) {//获得T[]的元素T类型 config = GetCollectionConfig(stype.GetElementType(), dst.GetType().GetElementType()); } var mapper = new AutoMapper.Mapper(config); dst = mapper.Map<d>(src); } private static AutoMapper.MapperConfiguration GetCollectionConfig(Type schildType, Type dchildType) { var config = new AutoMapper.MapperConfiguration(cfg => cfg.CreateMap(schildType, dchildType)); return config; } }
使用:
1.单对象:
var dbM = db.First();
var dm=new NewModel(); //拷贝到的对象
Mapper.Map(dbM,ref dm);
2.List
var list =linqQueryDB().ToList();
var dlist = new List<NewModel>(); //拷贝到的对象
Mapper.Map(list,ref dlist);
3.Array
var sarr = list.ToArray();
var darr = new NewModel[0]; //拷贝到的对象
Mapper.Map(sarr, ref darr);