0

我浏览了所有帖子,终于让 setCell 使用硬编码值,但不使用 options.rowId。

 function StatusFormatter(cellvalue, options, rowObject) {
    if (cellvalue == 'C'){
        jQuery("#list").setCell(options.rowId , 'SOORDLINE', '', { color: 'red' });
        jQuery("#list").setCell("[2.000]", 'SOORDLINE', '', { color: 'red' });
        jQuery("#list").setCell('[2.000]', 'SOREQDATE', '', { color: 'red' });
        jQuery("#list").setCell(options.rowId, 'SOPRICE', '', { color: 'red' });
    }
    return cellvalue;
    };  

FIRST 和 LAST 行不起作用,但带有硬编码 rowId 的 2 行起作用。我检查了 option.rowId 中返回的内容,它们与硬编码值相同,(当然取决于行。我错过了什么?请帮忙。我看不到行或值之间有任何区别。

已编辑-

我尝试了答案,这似乎是我需要的。我尝试了以下

      { name: 'SOORDLINE', index: 'SOORDLINE', width: 25, search: false ,celattr: function () { return ' style="color: red"'; }
},

至少在我深入逻辑之前让它们全部变红,它对我没有任何作用。

4

1 回答 1

1

抱歉,您以绝对错误的方式使用自定义格式化程序。自定义格式化程序的目标是提供 HTML 片段来填充相应列中单元格的内容。因此,将在创建id 等于的行之前调用。此外,出于性能目的,通常是一种用途。在这种情况下,网格的全部内容(网格的整个主体)将首先构造为字符串,然后才在一次操作中将其放置在网格主体中。它提高了性能,因为在放置任何元素后,Web 浏览器必须重新计算页面上所有其他元素的位置。StatusFormatteroptions.rowIdgridview: true

如果要在SOORDLINE单元格上设置文本颜色,则应cellattr改为:

celattr: function () { return ' style="color: red"'; }

celattr也可以在表单中使用,celattr: function (rowId, cellValue, rawObject) {...}您可以测试rawObject其代表任何列的值的属性,并根据单元格值返回单元格样式。

或者,您可以枚举其中的行loadComplete并在<tr>元素上设置样式,而不是为每一行设置相同的样式。以答案为例。

于 2011-12-20T20:06:16.127 回答