从Javascript for jqGrid通过JSON发送服务器端对象

Sending a server-side object via JSON from Javascript for jqGrid

本文关键字:服务器端 对象 JSON 通过 Javascript for jqGrid      更新时间:2023-09-26

我的服务器端代码中有一个类,比如说,类似于这样的类:

public class foo
{
   public int FieldOne { get; set; }
   public string FieldTwo { get; set; }
   public float FieldThree { get; set; }
}

现在,在我的客户端代码中,有一个表单将数据加载到输入中,这些输入用于从数据库中检索信息,然后必须将这些信息加载到jqGrid中。

我知道如何从表单中获取服务器端函数/操作数据,如果它是[HttpPost]的形式,比如:

[HttpPost]
public ActionResult Index (foo model)
{
   ...
}

但是我无法让网格调用这个方法。我已经将jqGrid的参数"url"设置为"Controller/Index",但它没有调用它。

有这样的称呼吗?或者还有其他方法可以通过Javascript以对象格式发送表单信息吗?

谢谢。

UPD:

这是网格代码:

grid.jqGrid({
        url: "Controller/Action",
        datatype: 'json',
        emptyrecords: "No hay proyectos cargados",
        colNames: ['Code', 'Desc', 'Rev', 'Client'],
        colModel: [
                 { name: 'Code', index: 'Code', width: 100 },
                 { name: 'Desc', index: 'Desc asc, Desc', width: 200 },
                 { name: 'Rev', index: 'Rev', width: 100, align: "right" },
                 { name: 'Client', index: 'Client', width: 200, align: "right" }
               ],
        rowNum: 10,
        loadonce: false,
        sortname: 'Code',
        viewrecords: true,
        sortorder: "desc",
        height: 'auto',
        caption: ""
    });

如果我更改@URL.Action()生成的URL也是一样的。

在网格中添加此行。

mtype: 'GET'

现在,您的网格正在尝试一个GET(默认)请求,请求只执行POST操作(由于您应用的属性)。或者,您可以删除POST限制,并将AllowGet选项添加到return Json(*******)中。

可能不止一个问题,但让我们从简单的事情开始:)

-编辑-

此外,正如评论中所提到的,Fiddlers+Firebugs/Chrome控制台在使用javascript/ajax/json时有很大帮助,因为当出现错误时,它们不会输出任何视觉效果。