2

例如,我有这堂课

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 中创建整个对象,然后仅更改修改的值。

我希望我对我糟糕的英语足够清楚

4

1 回答 1

0

ķ; 如果我重新表述:您想将所有具有非空值的属性复制到现有对象上。好吧,第一个问题(如您所述)是您不能拥有intthat is null。幸运的是,您可以通过简单地采取务实的步骤来解决这个问题,即 makeAgeIda 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; }
}

所以现在我们只有“复制所有非空值”。为此看看这个现有的答案,这有点像你的反射方法,但它使用 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);

还可以对其进行调整以对现有对象之一进行就地合并。

于 2012-09-14T09:33:23.000 回答