我有一个 jqGrid 表,与这个问题相同,我从服务器加载信息,但我存储在本地,所以我将选项数据类型设置为“本地”。
我还设置了删除按钮来使用这个功能。它必须从数据库和网格中删除该行。
var grid = $('#grid');
grid.jqGrid('navButtonAdd', '#pager',
{
caption: "",
buttonicon: "ui-icon-trash",
position: "first",
title: "Delete",
cursor: "pointer",
id: 'del_list',
onClickButton: function del(event) {
var rowID = grid.jqGrid('getGridParam', 'selrow');
if (rowID === null) {
$('<div title="Error"><p>Error</p></div>').dialog({
modal: true,
width: 350,
buttons: {Aceptar: function () {
$(this).dialog("close");
}},
dialogClass: "ui-jqdialog"
});
}
else {
grid.jqGrid('delGridRow', rowID,
{
width: 400,
delicon: [true, "left", "ui-icon-cancel"],
cancelicon: [true, "left", "ui-icon-close"],
beforeShowForm: function (form) {
SetFormsSize('#delmodtGrid');
},
caption: "Delete",
msg: "asdasdasd",
onclickSubmit: function (params, postdata) {
var code = parseInt(grid.find('tr:eq(' + rowID + ')').find('td:eq(0)').text());
var ver = parseInt(grid.find('tr:eq(' + rowID + ')').find('td:eq(2)').text());
var add_data = {ProjectID: code, VersionID: ver};
return add_data;
},
afterComplete: function (response, postdata) {
if (response.responseText === "Success") {
$('<div title=""><p>asdasdas</p></div>').dialog({
modal: true,
width: 400,
buttons: {Aceptar: function () {
$(this).dialog("close");
}},
dialogClass: "ui-jqdialog"
});
}
else {
$('<div title="Error: ' + response.responseText + '"><p>asdasdasd</p></div>').dialog({
modal: true,
width: 400,
buttons: {Aceptar: function () {
$(this).dialog("close");
}},
dialogClass: "ui-jqdialog"
});
}
}
});
}
}
});
我有一个操作服务器端来处理数据库中的删除。我有一个 try-catch 语句,它不会抛出任何异常。使用 Firebug,我得到了成功的 POST 请求以及响应(我添加了一个 afterSubmit 选项函数并检查 postdata)。所以我相信问题在于 jqGrid 的设置。
在它通过服务器端代码之后(并且,当我设置它时,在触发 afterSubmit 事件之后),这是我得到的错误(翻译自西班牙语):
运行时错误 Microsoft JScript:对象不接受属性或方法“拆分”
它在句子中影响第 331 行的 jquery.jqGrid.min.js
if(d[e.p.id].reloadAfterSubmit&&e.p.datatype!="local")
a(e).trigger("reloadGrid");
else{
var A=[];
A=H.split(",");
...
}
从完整的功能。产生错误的部分是 else 子句的第二句。