我有几个可编辑的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;
是否可以通过格式化程序解决此问题?
答案 0 :(得分:1)
类"not-editable-cell"
实际上仅用于单元格编辑。内联编辑仅分析"not-editable-row"
来电。您可以更改jqGrid的源代码,但在发布新版本的jqGrid后,您将遇到维护自定义更改的问题。因此,更好的方法是在the trirand forum中发布您的建议。
作为一种解决方法,您可以使用我所描述的here和here的技巧。这个想法很简单:您可以根据单元格包含临时修改editable
属性。在您调用editRow方法后,您可以直接重置editable
属性,因为已经创建了编辑字段。