1

从 mvc 4 中的控制器,我使用实体框架从数据库中的模型请求对象集合:

    [HttpPost]
    public ActionResult RequestDbObjects()
    {
        List<MyObjectType> objCollection;
        using (DataContext context = new DataContext())
        {
            objCollection= context.MyObjects.Where(o => o.TypeId == 1).OrderBy(k => k.Name).ToList();
        }

        return Json(objCollection);
    }

模型:

[Table("MyObjects")]
public class MyObjectType
{
    [Key]
    [DatabaseGeneratedAttribute(DatabaseGeneratedOption.Identity)]
    public int Id { get; set; }

    [Required]
    public string Name { get; set; }

    [Required]
    public string Description { get; set; }

    [Required]
    [ForeignKey("Type")]
    public int TypeId { get; set; }
    public virtual Type Type{ get; set; }
}

[Table("Type")]
public class Type
{
    [Key]
    [DatabaseGeneratedAttribute(DatabaseGeneratedOption.None)]
    public int Id { get; set; }

    [Required]
    public string Name { get; set; }
}

在视图中,使用脚本:

   function recollectData() {         
       $.ajax({
           url: "/Controller/RequestDbObjects/",
           type: 'POST',
           success: function (dataCollection) {
              for(var obj in dataCollection)
              {
                 var value = dataCollection[obj];
              }
           },
           error: function () {
               alert('Cannot retrieve the data');              
           }
       });             
   };

在上面的控制器中,首先我调用控制器中的操作,该操作使用实体框架从数据库请求数据,然后从返回到脚本的对象列表中,我想迭代它们,并为它们中的每一个读取一些属性和做一些东西,但我不知道怎么做。想法?

4

2 回答 2

1

您的成功处理程序返回数据。如果它是一个 JSON 对象,你可以这样读:

success: function (data) {
    for(var property in data) {
        var value = data[property];
    } 
}

如果你返回一个数组:

success: function (data) {
    for(var i=0; item=data[i]; i++) {

    } 
}
于 2013-09-21T12:10:43.150 回答
1

您必须返回 ActionResult,而不是 List:

[HttpPost]
public ActionResult RequestDbObjects()
{
    List<MyObjectType> objCollection;
    using (DataContext context = new DataContext())
    {
        objCollection= context.MyObjects.Where(o => o.TypeId == 1).OrderBy(k => k.Name).ToList();
    }

    return Json(objCollection);
}
于 2013-09-21T12:20:08.950 回答