2

是否可以在输出之前隐藏某些字段?

为了简单起见,假设我有User一个Image用户可以有多个图像。

用户

public class User
{
    public int Id { get; set; }
    public string Name { get; set; }
    public IEnumerable<Image> Images { get; set; }
}

输出

{
    Id: "1",
    Name: "Steve"
}

现在我想输出User有图像和没有图像。有可能做这样的事情吗?
_db.Users.SingleOrDefault(x => x.Id == id).Except(x => x.Images);

  • 这可以通过添加来实现,[JsonIgnore]但这不是一个选项,因为我想输出Images一些不同的请求。
  • 这可以通过输出匿名对象来实现,但这不是一个选项。
  • 这可以通过创建 DTO 来实现,但即便如此,我怎样才能将属性从模型自动分配给 dto?想象一下,我有 30 个字段,我不想手动分配它们。
4

2 回答 2

0

想象一下,我有 30 个字段,我不想手动分配它们。

自动映射器来救援!

PM> Install-Package AutoMapper

DTO:

public class User
{
    public int Id { get; set; }
    public string Name { get; set; }
    public IEnumerable<Image> Images { get; set; }
}

public class UserInfo
{
    public int Id { get; set; }
    public string Name { get; set; }
}

代码:

Mapper.CreateMap<User, UserInfo>();

var user = new User { Id = 1, Name = "Bob" };

var userInfo = Mapper.Map<User, UserInfo>(user);

return Json(new { userInfo });
于 2013-08-08T17:33:43.967 回答
0

我认为这也是一个值得您关注的解决方案:您可以定义一些base classinterface包含您想要的元素,如下所示:

public class UserBase {
  public int Id {get;set}
  public string Name {get;set;}
}
public class User : UserBase {
  public IEnumerable<Image> Images { get; set; }
}

//or using interface, I think this is better
public class IUserBase {
  int Id {get;set}
  string Name {get;set;}
}
public class User : IUserBase {
  public int Id { get; set; }
  public string Name { get; set; }
  public IEnumerable<Image> Images { get; set; }
}

然后在您的LINQ查询中,您可以执行以下操作:

var result = users.Select(x=>(IUserBase)x);
foreach(var user in result)
   System.Diagnostics.Debug.Print(user.Id + " : " + user.Name);//There is no `Images` element here except using explicitly cast to User type.
于 2013-08-08T18:15:46.507 回答