Asp.net mvc 4 在调用后端之前调用aftersavefunc JQGrid

Asp.net mvc 4 在调用后端之前调用aftersavefunc JQGrid,asp.net-mvc-4,jqgrid,Asp.net Mvc 4,Jqgrid,我有一个jqgrid,带有内联编辑和自定义按钮,如果保存失败,我将尝试显示自定义消息或弹出窗口: editurl: '@Url.Action("UpdateMatrixData")', datatype: "json", postData: { sp: function () { return getFilter(); } },

我有一个jqgrid,带有内联编辑和自定义按钮,如果保存失败,我将尝试显示自定义消息或弹出窗口:

editurl: '@Url.Action("UpdateMatrixData")',
                datatype: "json",
                postData: {
                    sp: function () { return getFilter(); }
                },
                postData: {
                    StartDate: function () { return $("#StartDate").val(); },
                    EndDate: function () { return $('#EndDate').val(); },
                },
                gridComplete: function ()
                {
                    var ids = jQuery("#evGrid").jqGrid('getDataIDs');
                        for (var i = 0; i < ids.length; i++)
                        {
                            var cl = ids[i];
                            be = "<input style='height:15px;width:15px;' title='Edit selected row' type='button' class='EditGridButton'  onclick=\"jQuery('#evGrid').editRow('" + cl + "');\" />"
                            se = "<input style='height:15px;width:15px;' title='Save row' type='button' class='SaveButton'  onclick=\"jQuery('#evGrid').saveRow('" + cl + "', '', '', '', reload());\" />"  // dont Need to refesh grid after saving row - call reload function
                            ce = "<input style='height:15px;width:15px;' title='Cancel row editing' type='button' class='CancelButton'  onclick=\"jQuery('#evGrid').restoreRow('" + cl + "');\" />";
                            jQuery("#evGrid").jqGrid('setRowData', ids[i], { act: be + se + ce });
                        }
                },

 function reload(rowid, response) {

            alert(response)
            $(this).jqGrid('setGridParam', { datatype: 'json' });
            $(this).trigger('reloadGrid', [{ page: 1 }]);
        }

您在使用中的主要错误

onclick=\"jQuery('#evGrid').saveRow('" + cl + "', '', '', '', reload());\"
而不是

onclick=\"jQuery('#evGrid').saveRow('" + cl + "', '', '', '', reload);\"

reload
是jqGrid将调用的回调函数。如果您使用
reload()
,那么在jqGrid执行此操作之前,您的代码将调用
reload
mit空参数(jqGrid根本不获取函数的引用,而是从
reload()
返回
未定义的

@Standage:欢迎!通常,代码的许多部分都应该更改。使用
setRowData
修改循环中的网格内容是填充网格最慢的方法。相反,最好使用自定义格式化程序或预定义的格式化程序,如
formatter:“actions”
。另一方面,有时人们没有时间重写旧代码,重要的是让它工作起来。
onclick=\"jQuery('#evGrid').saveRow('" + cl + "', '', '', '', reload);\"