删除jqGrid中的行时出现运行时错误

时间:2012-09-10 19:22:51

标签: jquery jqgrid

我有一个jqGrid表,来自this problem的同一个表,我从服务器加载了信息,但我在本地存储,所以我将选项数据类型设置为'local'。

我还设置了删除按钮以使用此功能。它必须从数据库和网格中删除行。

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:Object不接受属性或   方法'拆分'

它影响第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子句的第二句。

1 个答案:

答案 0 :(得分:0)

相关问题