У меня есть сетка с несколькими редактируемыми столбцами
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',
По какой-то причине мне нужно иметь несколько нередактируемых ячеек в этих столбцах
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');
...
}
}
}
Поэтому в некоторых строках есть обе ячейкиредактируемый (имя, имя2), только один (имя или имя2)
У меня нет проблем, если я использую 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;
Возможно ли решить эту проблему с помощью форматера?