1

我正在使用 inlineNav 编辑选项来添加和编辑行。数据正在正确更新到数据库中,但是在成功保存后我找不到刷新网格而不发回服务器的方法。

我发现的所有问题和答案都建议做 $.('grid').trigger('reloadGrid');

但是,如果来自服务器的响应已经包含所需的数据,这似乎是不必要的。这主要是添加新记录时的问题,ID 值显示为 jqg1。

我正在使用带有 jqGrid 4.4.4 的 ASP.NET MVC4。

这是我的看法

  $(document).ready(function () {
    var emptyMsgDiv = $('<div>No school codes to display.</div>');
    var grid = $('#tblSchools');

    grid.jqGrid({
        datatype: 'json',
        viewrecords: true,
        url: '@Url.Action("SchoolsGridData")',
        editurl: '@Url.Action("EditSchoolsGridData")',
        colNames: ['School ID', 'Name', 'SACE Number', 'School Code', 'LEA Code', 'DFEE Code', 'Active'],
        colModel: [
                    { name: 'SchoolId', index: 'SchoolId', width: 80, key: true },
                    { name: 'Name', index: 'Name', width: 190, editable: true },
                    { name: 'SaceSchoolNumber', index: 'SaceSchoolNumber', width: 105, editable: true, sortable: false },
                    { name: 'Code', index: 'Code', width: 105, editable: true, sortable: false },
                    { name: 'LeaCode', index: 'LeaCode', width: 80, editable: true, sortable: false },
                    { name: 'DfeeCode', index: 'DfeeCode', width: 80, editable: true, sortable: false },
                    { name: 'Active', index: 'Active', width: 80, editable: true, sortable: false }
        ],
        shrinkToFit: true,
        height: "100%",
        caption: 'School list',
        rowNum: 10,
        rowList: [10, 15, 20],
        emptyrecords: 'No school codes to display.',
        pager: '#schoolsPager',
        loadComplete: function () {
            var count = grid.getGridParam();
            var ts = grid[0];
            if (ts.p.reccount === 0) {
                grid.hide();
                emptyMsgDiv.show();
            } else {
                grid.show();
                emptyMsgDiv.hide();
            }
        }
    }).trigger('reloadGrid', [{ page: 1 }]);

    emptyMsgDiv.insertAfter(grid.parent());

    grid.jqGrid('navGrid', "#schoolsPager", { edit: false, add: false, del: true });
    grid.jqGrid('inlineNav', '#schoolsPager', {
        addParams: {
            position: "last",
            addRowParams: {
                "keys": true,
                "aftersavefunc": function (rowid, response) {
                    alert('row: ' + rowid + ', response: ' + $.param(response));
                }
            }
        },
        editParams: {
            "aftersavefunc": function (rowid, response) {
                alert('row: '+rowid+', response: '+response);
            }
        }
    });

  });
</script>
<h3>Maintain Schools</h3>

<table id="tblSchools"></table>
<div id="schoolsPager" class="gridPager"></div>

和我的控制器

public JsonResult EditSchoolsGridData(string oper, string SchoolId, string Name, string SaceSchoolNumber, string Code, string LeaCode, string DfeeCode, string Active)
{
  [Update Logic]

  return SchoolsGridData(string.Empty, "asc", 1, 10);
}

[HttpGet]
public JsonResult SchoolsGridData(string sidx, string sord, int? page, int? rows)
{
  [Get data logic]
}

我可以看到在 aftersavefunc 中显示的响应 json,但找不到将其绑定到网格的方法。

我想要做的甚至可能吗?

4

1 回答 1

0

您可以使用 addRowData 方法,该方法将通过重新加载网格将数据设置为网格

jQuery("#tblSchools").jqGrid('addRowData', response.SchoolId, response, "first");

有关更多详细信息,请参阅 jqgrid 方法 wiki

于 2013-03-08T02:30:38.170 回答