例如,我有这堂课
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; } }
}
以及我在表格中显示的人员列表。在这个表中有一个“就地/内联编辑”:某些人的属性在表中有一个单元格(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
。
我该如何解决这个问题?考虑到我不能使用:
- 可以为空的类型,因为我应该在整个项目中修改这么多行代码;
- 该表可能不包含 Person 的所有属性,因此我无法在 javascript 中创建整个对象,然后仅更改修改的值。
我希望我对我糟糕的英语足够清楚