对象拷贝之AutoMapper简单封装

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);

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章