我该如何做List<;用户定义类型>;=列表<;用户定义类型2>;
本文关键字:定义 类型 gt lt 用户 列表 何做 List | 更新日期: 2023-09-27 18:08:53
我有两个具有用户定义类型的列表例如List<User_Master>
和List<User_Master_Temp
>User_Master
和User_Master_Temp
都包含具有相同名称的相同类型的变量。如何分配这些类型的列表
传统的做法是
userMaster.UserName = userMasterTemp.UserName;
userMaster.UserEmail = userMasterTemp.UserEmail;
userMaster.UserSalary = userMasterTemp.UserSalary;
为什么我需要这个?
我使用的是EF 5(数据库优先方法(和MVC 4,我在模型中应用我的数据注释验证,如果我更新我的edmx文件,然后运行自定义工具,我所有的验证都会消失
所以我写了我自己的视图模型类,它和原始模型类的视图模型一样,我在那个视图模型类中应用了我的数据注释。
考虑使用Automapper使用定义的配置或某种约定将一个自定义实例转换为另一个。它有一个约定,如果属性具有相同的名称并且类型兼容(默认情况下可以使用(,则映射属性。下一个代码演示它的用法
void Main()
{
List<UserMaster> users = new List<UserMaster>{
new UserMaster{Name = "Bob", Email = "bob@mail.ru", Salary = 10},
new UserMaster{Name = "Jack", Email = "jack@mail.ru", Salary = 20},
new UserMaster{Name = "John", Email = "john@mail.ru", Salary = 40},
};
Mapper.CreateMap<UserMaster, UserMasterTemp>();
List<UserMasterTemp> usersTemp = Mapper.Map<IEnumerable<UserMaster>,
List<UserMasterTemp>>(users);
usersTemp.ForEach(Console.WriteLine);
}
class UserMaster
{
public string Name { get; set; }
public string Email { get; set; }
public decimal Salary { get; set; }
}
class UserMasterTemp
{
public string Name { get; set; }
public string Email { get; set; }
public decimal Salary { get; set; }
//formating for demo purposes
public override string ToString()
{
return string.Format("Name: {0}, Email: {1}, Salary: {2}",
Name, Email, Salary);
}
}
打印:
Name: Bob, Email: bob@mail.ru, Salary: 10
Name: Jack, Email: jack@mail.ru, Salary: 20
Name: John, Email: john@mail.ru, Salary: 40
User_Master.Select(m=>new User_Master_Temp(){/*assign the Properties*/});
如果你正在使用一些对象到对象的映射器,你可以使用"我使用胶水"来做这件事。
var Mapping = new Mapping<User_Master, User_Master_Temp>();
Mapping.AutoRelateEqualNames();
User_Master.Select(m=>Mapping.Map(m));
您可以使用automapper来映射对象。
这是文件:
点击此处
您可以在Visual Studio中使用NUGET PACKAGE来获取AUTOAPPER。
或者,如果您不想使用工具,可以使用以下方法:
public static void CopyIdenticalObjects(object source, object destination)
{
FieldInfo[] destinationFields = destination.GetType().GetFields(BindingFlags.NonPublic | BindingFlags.Instance | BindingFlags.Public);
foreach (FieldInfo sourceField in source.GetType().GetFields(BindingFlags.NonPublic | BindingFlags.Instance | BindingFlags.Public))
for (int counter = 0; counter < destinationFields.Length; ++counter)
try
{
if (destinationFields[counter].Name.Equals(sourceField.Name))
{
destinationFields[counter].SetValue(destination, sourceField.GetValue(source));
break;
}
}
catch { }
}