jqGrid treeGrid editRow和not-editable-cel

时间:2012-02-08 13:16:16

标签: jquery jqgrid

我有几个可编辑的cols

的网格
colModel: [
    { 
        name: 'id',
        width: 1,
        hidden: true,
        key: true,
        resizable: false
    },
    {
        name: 'name',
        editable: true,
        sortable: false,
        resizable: false
    },
    {
        name: 'name2',
        editable: true,
        sortable: false,
        resizable: false
    },
    treeGrid: true,
    treeGridModel: 'adjacency',
    ExpandColumn: 'name',

出于某种原因,我需要在这些cols中有一些不可编辑的单元格

    loadComplete: function() {
        var ids = grid.jqGrid('getDataIDs');

        for (var i=0;i<ids.length;i++) {
            var id=ids[i];
            var row_data = $(this).jqGrid('getRowData', id);

            if (row_data.zzz > 0) {
                if (row_data.zzz > 1) 
                    grid.jqGrid('setCell',id,'name2','','not-editable-cell');
                else
                ...
            }
            else {
                grid.jqGrid('setCell',id,'name','','not-editable-cell');
                ...
            }
        }
    }

所以有些行的两个单元格都可以编辑(name,name2),有些只有一行(name或name2)

我没有任何问题如果我使用editCell 但是editRow没有注意不可编辑的单元格类

我通过编辑jquery.jqGrid.src.js解决了这个问题 我认为这是非常糟糕的方式

$.jgrid.extend({
//Editing
    editRow : function(rowid,keys,oneditfunc,successfunc, url, extraparam, aftersavefunc,errorfunc, afterrestorefunc) {
.......
        return this.each(function(){
            var $t = this, nm, tmp, editable, cnt=0, focus=null, svr={}, ind,cm;
            if (!$t.grid ) { return; }
            ind = $($t).jqGrid("getInd",rowid,true);
            if( ind === false ) {return;}
            editable = $(ind).attr("editable") || "0";
            if (editable == "0" && !$(ind).hasClass("not-editable-row")) {
                cm = $t.p.colModel;
                $('td[role="gridcell"]',ind).each( function(i) {
///
                    if (!$(this).hasClass("not-editable-cell")) {
///
                    nm = cm[i].name;
                    var treeg = ($t.p.treeGrid===true && nm == $t.p.ExpandColumn) ? true : false;

是否可以通过格式化程序解决此问题?

1 个答案:

答案 0 :(得分:1)

"not-editable-cell"实际上仅用于单元格编辑。内联编辑仅分析"not-editable-row"来电。您可以更改jqGrid的源代码,但在发布新版本的jqGrid后,您将遇到维护自定义更改的问题。因此,更好的方法是在the trirand forum中发布您的建议。

作为一种解决方法,您可以使用我所描述的herehere的技巧。这个想法很简单:您可以根据单元格包含临时修改editable属性。在您调用editRow方法后,您可以直接重置editable属性,因为已经创建了编辑字段。