使用setGridParam将json数据加载到jqgrid中

时间:2011-07-25 12:38:24

标签: jqgrid

我在使用setGridParam设置jqgrid的url时遇到了一些问题。

我收到消息:“f未定义”。

我的设置:

       $("#prices").jqGrid({
    colModel: [
           ...
        ],
    pager: jQuery('#pricePager'),
    ajaxGridOptions: { contentType: "application/json" },
    mtype: 'POST',
    loadonce: true,
    rowTotal: 100,
    rowNum: -1,
    viewrecords: true,
    caption: "Prices",
    height: 300,
    pgbuttons: false,
    multiselect: true,
    afterInsertRow: function (rowid, rowdata, rowelem) {
        // ...
    },
    beforeSelectRow: function (rowid, e) {
      // ...
    },
    onSelectRow: function (rowid, status) {
       // ...
    }
}); 

获取数据:

$("#prices").setGridParam({ datatype: 'json', page: 1, url: '@Url.Action("GridDataPrices")', postData: JSON.stringify(selections) });

$("#prices").trigger('reloadGrid');

响应是非编码的json:

{"total":1,"page":1,"records":100,"rows":[{"id":160602948,"StartDate":"\/Date(1311717600000)\/","Duration":7,"Price":1076.0000,"Code":"code"},{"id":160602950,...}]}

但是,我使用firebug得到以下消息:

“f未定义”

我首先使用addJSONData工作,但必须替换它,因为我想保留本地排序。

提前致谢。

1 个答案:

答案 0 :(得分:6)

上传代码后,一切都将清除。你的主要错误是以下几点:

  • 您应该在jqGrid中包含datatype: 'local'。默认值为“xml”。
  • JSON数据已命名属性,因此您必须使用jsonReader: { repeatitems: false }(有关详细信息,请参阅the documentation
  • 您在colModel中使用“ArivalCodeWay”,在JSON数据中使用“ArrivalCodeWay”。所以你应该修复相应的jqGrid列的名称
  • 解码date格式的"\/Date(1312840800000)\/",您应该在相应列中包含formatter:'date'
  • 同样地,我觉得在“持续时间”列中包含formatter:'int', sorttype:'int',在“价格”列中包含sorttype:'number', formatter:'number', formatoptions: { decimalPlaces:4, thousandsSeparator: "," }
  • 如果您使用JSON.stringify,则应包含json2.js,以确保您的代码可以在所有网络浏览器中使用。

您可以找到here修改后的演示(包括其他一些小改动)。如果单击“单击我”按钮,将加载网格包含。