0

我有一个 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 子句的第二句。

4

1 回答 1

0

没关系,解决方案在这里:删除行时出现 jqgrid 错误,这指向这里的答案:http ://www.trirand.com/blog/?page_id=393/bugs/4-2-0-g-split-is -不是功能错误/

于 2012-09-10T19:25:57.150 回答