情景描述:
在ASP.NET MVC 4 WebApi框架下,将Linq To Entity查询出来的实体对象序列化为Json格式传回客户端。
问题一: 出现Loop Reference问题导致无法正常序列化查询出来的数据项为Json格式。
通常解决方案是设置entity framework停用LazyLoading和ProxyCreation,这样序列化单个对象获取的数据可能并不满足前台所需。
http://www.dotblogs.com.tw/programlin/archive/2012/10/15/77500.aspx
此时往往需要使用自定义数据传输对象来填充数据。
问题二: 每次需定义DTO数据传输对象比较繁琐。
比较理想的解决方案是通过使用匿名对象Anonymous Type,将需要获取数据填充到匿名对象最后序列化为Json。
如 return Entity.jobs.Select(p => new
{
ID = p.ID,
Subject = p.Subject,
Description = p.Description,
ShowCreatedDate = p.ShowCreatedDate,
Nickname = p.Nickname,
Proposals=p.Proposals
}).ToList()
);
其中ShowCreatedDate是由Job partial class添加的拓展属性计算出来的,Proposals是Job的导航对象。
很方便通过Entity Framework延迟查询功能取出所需数据,最后由匿名对象包装序列化传回到前台。