情景描述:

在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延迟查询功能取出所需数据,最后由匿名对象包装序列化传回到前台。

 

 

 

posted on 2013-01-21 21:06  露水丛生  阅读(744)  评论(0编辑  收藏  举报