0

我有一个像这样的对象模型

public class Parent{
 public int Id;
 public string Name;
 public Child Sibling 
}

public class Sibling {
 public int Id;
 public string Name;
 public Cousin Cousin
}

public class Cousin{
 public int Id;
 public string Name;
 public DateTime CreatedDate;
}

我正在尝试展平或投影?像这样的模型

public class ViewModelSibling {
   public int Id;
   public string Name;
}
public class ViewModel{
 public int ParentId;
 public string ParentName;
 public ViewModelSibling Sibling;
 public ViewModelSibling Cousin;
 public DateTime? CousinCreatedDate;
}

其中 Sibling 和 Cousin 可以为 Null

控制器代码

 [HttpPost]
 public virtual ActionResult GetGridItems()
 {
     IQueryable<Parent> parents = GetParentsWhereCriteriaMet();
     var data = parents.Select( p => new ViewModel{
                       ParentId = p.Id,
                       ParentName = p.Name,
                       Sibling = new ViewModelSibling  { Id = p.Sibling.Id, Name = p.Sibling.Name},// if p.Sibling is null and exception is thrown
                       Cousin= new ViewModelSibling  {Id =p.Sibling.Cousin.Id, Name = p.Sibling.Cousin.Name}// if p.Sibling or p.Sibling.Cousin are null and exception is thrown
                       CousinCreatedDate = p.Sibling.Cousin.CreatedDate
                       } )
     return new JsonResult { Data = data };
 }

我试图避免使用 ToList() 因为我不希望返回所有父记录。ViewModel 将使用 Ajax 绑定到 Telerik Grid,这将处理分页。我不想使用 AutoMapper,因为我不想返回所有字段和记录。

如何在不使用 ToList() 的情况下展平此模型?

4

1 回答 1

0

使用任一

Sibling = p.Sibling == null ? null : new ViewModelSibling(...)

或者

Sibling = new ViewModelSibling{ Id = p.Sibling == null ? 0 : p.Sibling.Id, etc ... }

根据您的要求。

ETC...

于 2012-03-16T19:39:42.240 回答