jquery - 在免费 jqgrid 中添加新行后如何从服务器设置行 ID

标签 jquery jqgrid free-jqgrid

如果使用表单编辑添加新行、保存到服务并且服务器返回自动生成的行 ID,则免费 jqgrid 不会设置行 ID。 后续编辑添加的行会导致错误。

我使用下面的代码尝试了 github 上的免费 jqgrid,但问题仍然存在。

要重现,请在浏览器中打开下面的页面,单击加号按钮添加行并提交,然后取消 ID 列为空。代码包含:

           afterSubmit: function (response, postdata) {
               return [true, '', '100'];

模拟返回远程 ID 100 的服务器响应。 所以添加后 Id 列应包含 vlaue 100。

我也在 github 上发布了它作为免费的 jqgrid 问题,但没有得到任何回复。 如何修复它以便可以使用表单编辑添加行?

<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
    <meta http-equiv="X-UA-Compatible" content="IE=edge"/>
    <link rel="stylesheet" type="text/css" href="http://code.jquery.com/ui/1.11.4/themes/redmond/jquery-ui.css"/>
    <link rel="stylesheet" type="text/css" href="http://cdn.jsdelivr.net/free-jqgrid/4.8.0/css/ui.jqgrid.css"/>
    <link rel="stylesheet" href="http://netdna.bootstrapcdn.com/font-awesome/4.3.0/css/font-awesome.min.css">
    <script type="text/javascript" src="http://code.jquery.com/jquery-1.11.2.min.js"></script>
    <script type="text/javascript" src="http://code.jquery.com/ui/1.11.4/jquery-ui.min.js"></script>
    <script type="text/javascript" src="http://cdn.jsdelivr.net/free-jqgrid/4.8.0/js/i18n/grid.locale-en.js"></script>
    <script type="text/javascript">
        $.jgrid = $.jgrid || {};
        $.jgrid.no_legacy_api = true;
        $.jgrid.useJSON = true;
    </script>
<script src="http://rawgit.com/free-jqgrid/jqGrid/master/js/jquery.jqgrid.src.js"></script>
    <script type="text/javascript">
        $(function () {
            "use strict";
            var mydata = [
                ],
                $grid = $("#list");

            $grid.jqGrid({
                datatype: "local",
                data: mydata,
                colNames: ["Client", "Id"],
                colModel: [
                    { name: "name", align: "center", editable: true },
                    { name: "id" }
                ],
                iconSet: "fontAwesome",
                pager: "#pager",
                gridview: true,
                autoencode: true,
                ignoreCase: true,
                onSelectRow: function (rowid) {
                    var $self = $(this),
                        savedRow = $self.jqGrid("getGridParam", "savedRow");
                    if (savedRow.length > 0) {
                        $self.jqGrid("restoreRow", savedRow[0].id);
                    }
                    $self.jqGrid("editRow", rowid, {
                        keys: true
                    });
                }
            })

.jqGrid('navGrid', {}, {},
{
}
})
;

        });
    //]]>
    </script>
</head>
<body>
    <table id="list"><tr><td></td></tr></table>
    <div id="pager"></div>
</body>
</html>

最佳答案

谢谢!这是 jqGrid 4.7 中的一个错误,请参阅 the line :

idname = url === 'clientArray' ? $t.p.keyName : opers.id;

免费的jqGrid是基于jqGrid 4.7的,所以它也有同样的问题。我刚刚发了the fix ,将上面的行更改为以下内容

idname = url === "clientArray" && p.keyName !== false ? p.keyName : opers.id;

现在问题应该解决了。

关于jquery - 在免费 jqgrid 中添加新行后如何从服务器设置行 ID,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29569696/

相关文章:

javascript - 使用 jqGrid 编辑回调发送额外参数

javascript - 如何放置选择元素和切换按钮以释放 jqgrid 工具栏

javascript - jqGrid 免费 : Help on design of handling multiple yearly calendars with monthly breakdown data

javascript - 如何使用 jQuery 禁用/启用按钮?

javascript - 获取javascript中对象上的所有事件监听器

jqgrid - Jqgrid 上的外部工具提示插件

jquery - 如何在免费的 jqgrid 中显示列上下文菜单中的所有列

javascript - 在可编辑的 div 中插入笑脸

javascript - 如何确保传入 Rails 服务器的请求是从 Rails View 发送的?

jquery - 使用 GET 从 jqGrid 中的列值链接到新页面