0

我正在寻找一种方法来禁用 jqGrid 行的编辑,其中 isPosted 列的值为 true。

使用操作格式化程序或双击行中的表单和内联编辑。需要禁用各种编辑。我在 jqGrid loadcomplete 中尝试了下面的代码。

这不会禁用表单编辑。还双击发布的行显示保存和取消按钮(所有列都处于只读模式)。

如何为发布的行禁用所有类型的行编辑?jqGrid 由远程 jqson 数据填充。

  loadCompete: function () {
    var
      postedCol = getColumnIndexByName($grid, 'isPosted'),
      cRows = $grid[0].rows.length,
      iRow,
      row,
      className,
      isPosted,
      cm = $grid.jqGrid('getGridParam', 'colModel'),
      l,
      iActionsCol = getColumnIndexByName($grid, '_actions');

    l = cm.length;
    for (iRow = 0; iRow < cRows; iRow = iRow + 1) {
            row = $grid[0].rows[iRow];
            className = row.className;
            isPosted = false;
            if ($.inArray('jqgrow', className.split(' ')) > 0) {
              isPosted = $(row.cells[postedCol]).find(">div>input:checked").length > 0;
              if (isPosted) {
                    if ($.inArray('jqgrid-postedrow', className.split(' ')) === -1) {
                        // todo: how to disable row editing and inline edit actions buttons.
                        // why those two lines do not disable
                        row.className = className + ' jqgrid-postedrow not-editable-row';
                        $(row.cells[iActionsCol]).attr('editable', '0'); 
                        $(row.cells[iActionsCol]).find(">div>div.ui-inline-del").hide();
                        $(row.cells[iActionsCol]).find(">div>div.ui-inline-edit").hide();
                    }
                }
            }
        }


css file:

.jqgrid-postedrow
{
    background-color: #FFFFD0;
    background-image: none;
}
4

1 回答 1

0

@Andrus,您可以在gridComplete 或LoadComplete 上检查isPosted 的值,如果它是真的,只需使用jquery 隐藏编辑按钮,您可以使用开发人员工具获取这些按钮的ID 对吗?

我有一个类似的要求,在某些行中我必须显示编辑按钮,而在某些行中我必须根据 jqgrid 中的数据隐藏它们。

所以我使用开发人员工具获得了这些按钮的 ID,并在 loadComlete 中检查了所有行的值并隐藏了按钮。我认为这也适合你。并谈论 onSelectRow 或 onDblClickRow 检查 isPosted 的值,如果它是真的,你应该从你的函数中返回 false 否则用这样的东西进行正常编辑

jQuery("#grid_id").editRow(id, properties);

于 2012-07-31T16:16:01.390 回答