Моя проблема сейчас заключается в попытке отправить идентификатор (editable: false) строки при редактировании этой строки.

Например, у меня есть сетка с столбцами ID пользователя (editable: false), имя пользователя (editable: true), имя (editable: true), фамилия (editable: true). При редактировании строки сетка отправляет только параметры имя пользователя, имя и фамилия. На стороне сервера мне нужен идентификатор пользователя, чтобы знать, к какому пользователю я применил эти новые значения.

EditUrl выглядит так:

editurl : CONTEXT_PATH+'/ajax/admin/savePart.do?category=1',

Благодарность

Это полный код:

$.jgrid.useJSON = true;
//http://www.trirand.com/jqgridwiki/doku.php?id=wiki%3Acommon_rules
$(document).ready(function() {
    //alert(CONTEXT_PATH);
    var lastsel;
    jQuery("#rowed3").jqGrid(
            {
                url : CONTEXT_PATH+'/ajax/getPartesByCategory.do?catid=<s:property value="categoryId" />',
                //url : '/autoWEB/text.html',
                datatype: "json",
                ajaxGridOptions: { contentType: "application/json" },
                jsonReader : { 
                    root: "rows", 
                    page: "page", 
                    total: "total", 
                    records: "records", 
                    repeatitems: false 
                },
                headertitles: true,
                colNames : [ 'ID', 'Pieza', 'Disponible'],
                colModel : [ {
                    name : 'piezaId',
                    index : 'piezaId',
                    align : "right",
                    width : 50, 
                    editable : false,
                    required : true
                }, {
                    name : 'descripcion',
                    index : 'descripcion',
                    width : 390,
                    editable : true,
                    required : true
                }, {
                    name : 'disponible',
                    index : 'disponible',
                    width : 80,
                    editable : true,
                    edittype : 'select',
                    editoptions:{value:"0:No;1:Si"},
                    required : true
                } ],
                rowNum : 20,
                rowList : [ 20, 40, 60, 80 ],
                pager : '#prowed3',
                sortname : 'piezaId',
                postData: {piezaId : lastsel},
                mtype:"POST",
                viewrecords : true,
                sortorder : "desc",
                onSelectRow : function(id) {
                    if (id && id !== lastsel) {
                        jQuery('#rowed3').jqGrid('restoreRow', lastsel);
                        jQuery('#rowed3').jqGrid('editRow', id, true);
                        lastsel = id;
                    }
                },
                editurl : CONTEXT_PATH+'/ajax/admin/savePieza.do?categoria=<s:property value="categoryId" />',
                caption : "Piezas"
            });
    jQuery("#rowed3").jqGrid('navGrid', "#prowed3", {
        edit : false,
        add : false,
        del : false
    });
})
2
Garis M Suero 5 Июл 2010 в 00:45

3 ответа

Лучший ответ

Ты можешь использовать

hidden: true, editable: true, editrules: { edithidden: false }, hidedlg: true

В определении столбца piezaId (ID). Параметр hidedlg в настоящее время не нужен, но может быть полезен, если вы решите использовать другие функции jqGrid.

2
Oleg 5 Июл 2010 в 06:28

Передача значений в строке GET сработала для меня.

editurl: '/ajax/update?line=1',
0
TheRealJAG 30 Дек 2016 в 08:23

В обратном вызове onSelectRow вы можете изменить editUrl так, чтобы он соответствовал вашему желанию, включая передачу нужного идентификатора.

$("#rowed3").jqGrid('setGridParam', {editurl:'whatever/url/you/need/with/the/id'});

JqGrid добавит все остальные необходимые параметры в этот редактор для вас.

3
Gregg 7 Июл 2010 в 17:14