Asp.net mvc 4 在调用后端之前调用aftersavefunc JQGrid
我有一个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(); } },
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);\"