我有一个使用自定义按钮进行内联编辑的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 }]);
}
但是响应为空吗?并在调用updateMatrixData方法之前调用它?
updateMatrixData返回Json(true)或Json(false)
return Json(isSucess);
答案 0 :(得分:1)
您使用
时遇到的主要错误onclick=\"jQuery('#evGrid').saveRow('" + cl + "', '', '', '', reload());\"
代替
onclick=\"jQuery('#evGrid').saveRow('" + cl + "', '', '', '', reload);\"
reload
是回调函数,它将由jqGrid调用。如果您使用reload()
,那么您的代码会调用reload
mit空的参数,然后再执行jqGrid的操作(jqGrid根本不获取该函数的引用,而是从{{ 1}})。