例如,我有这个课程
class Person{
private int _id = int.MinValue;
private string _name = string.Empty;
private int _age = int.MinValue;
private string _city = string.Empty;
public string Id{ get { return _id ; } set { _id = value; } }
public string Name{ get { return _name; } set { _name = value; } }
public int Age{ get { return _age; } set { _age = value; } }
public string City{ get { return _city ; } set { _name = city; } }
}
以及我在表格中显示的人员列表。在这个表中有一个"编辑就位/内联":某个Person的属性在表中有一个单元格(td),所以当我编辑一个单元格时,通过javascript / jquery,我创建具有更改值的json对象,我将其发送到服务器。 json对象仅包含已更改的属性:如果我编辑"名称" json对象将是:
{"obj":{"Id":"1","Name":"Anna"}}
但服务器的对象Person是
Id = 1, Name = "Anna", Age = 0, City = null
所以问题是:要执行更新存储过程,我必须创建具有所有原始值的对象,以修改属性的异常。在这个例子中,我想得到这个对象:
Id = 1, Name = "Anna", Age = 25, City = "New York"
要创建此对象,我使用此方法
public static TEntity CopyTo<TEntity>(this TEntity OriginalEntity, TEntity NewEntity){
PropertyInfo[] oProperties = OriginalEntity.GetType().GetProperties();
foreach (PropertyInfo CurrentProperty in oProperties.Where(p => p.CanWrite))
{
if (CurrentProperty.GetValue(OriginalEntity, null) == null)
{
CurrentProperty.SetValue(OriginalEntity, CurrentProperty.GetValue(NewEntity, null), null);
}
}
return OriginalEntity;
}
如果新对象Person
的属性值为null
,那么我会从原始Person
(NewEntity
)中获取原始值。这种方式不适用于数字,因为从客户端到服务器,Age
属性变为0
而不是null
。
我该如何解决这个问题?考虑到我不能使用:
我希望我对自己的英语不太清楚
答案 0 :(得分:0)
K表;如果我重新短语:您想要将具有非空值的所有属性复制到现有对象上。好吧,第一个问题(正如您所注意到的)是您不能拥有int
null
。幸运的是,你可以通过简单地采取务实的步骤来解决这个问题,即Age
和Id
Nullable<int>
,int?
,
class Person
{
public int? Id { get; set; }
public string Name { get; set; }
public int? Age { get; set; }
public string City { get; set; }
}
所以现在我们只需要“复制所有非空值”。对于那个,请查看this existing answer,这有点像你的反射方法,但它使用IL是非常愚蠢的。
使用示例:
var orig = new Person {Id = 1, Name = "Anna"};
var delta = new Person {Id = 1, Age = 25, City = "New York"};
var merged = Merger.Merge(orig, delta);
Console.WriteLine(merged.Id);
Console.WriteLine(merged.Age);
Console.WriteLine(merged.Name);
Console.WriteLine(merged.City);
也可以调整它来对其中一个现有对象进行就地合并。