在输出之前隐藏一些对象字段
本文关键字:对象 字段 隐藏 输出 | 更新日期: 2023-09-27 18:26:59
输出前是否可以隐藏某些字段?
为了简单起见,假设我有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个字段,我不想手动分配它们
假设我有30个字段,我不想手动分配它们。
Automapper救援!
PM>安装包自动映射
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 });
我认为这也是一个值得您注意的解决方案:您可以定义一些base class
或interface
,其中包含您想要的元素,比如:
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.