如何动态更改单元格格式



我使用dojo实现了一个数据网格,它每5秒更新一次。我使用下面的代码来更新数据网格。

jsonStore.fetch({
         query: {id:'*'},
         onComplete: function(items, result){
         dojo.forEach(items, function(item){
             jsonStore.setValue(item, "time" , data.update[0].netchange);
.....

'data'是我需要设置到网格的新数据,这是一个json对象,如下所示

var data = {"update":[{...}]}

我需要做什么,如果netchage是负的,我需要设置单元格颜色为红色。如果netchange是正的,它应该是绿色的。所以我需要一种动态改变单元格格式的方法。有人能告诉我怎么做吗?提前感谢

grid4 = new dojox.grid.DataGrid({
            query : {
                Title : '*'
            },
            id : "grid",
            jsId : "grid",
            clientSort : true,
            rowSelector : '0px',
            structure : layout4
        }, document.createElement('div'));
        grid4.setStore(jsonStore);
        dojo.byId("gridContainer4").appendChild(grid4.domNode);
var layout4 = [ {
            field : 'time',
            name : 'time',
            width : '40px',
            formatter: geticon()
        }, {
            field : 'netchange',
            name : 'netchange',
            width : '30px'
        } ];

在我回答这个问题之前,只是一个微不足道的用词不当,当你说,"动态更改单元格格式"。

您没有更改单元格formatter,您正在更改单元格的样式

每当将值加载到单元格中时,就调用格式化程序。此外,将为单元格所在的行调用onStyleROw函数。

这意味着您有两个选项来更改单元格的颜色。您可以在单元格范围内这样做,或者您可以让格式化器做一些简单的事情,例如用具有不同样式颜色的<span>包装值。我给你们看。

这是第一个不改变任何现有网格代码的解决方案,它将使用onStyleRow改变整个行。

解决方案1使用onStyleRow

步骤1。(连接onStyleRow)

dojo。connect(grid4, "onStyleRow", styleRowGridPayment);

步骤2。(Create you styleRowGridPayment method.)

var styleGridPayment = function(inRow) {
        if( null !== grid4.getItem( inRow.index ) ) {
            item = grid4.getItem( inRow.index );
            if( item.netchange < 0 ) {
                inRow.customStyles += "color:red;";
            } else {
                inRow.customStyles += "color:green;";
            }
         }
    }   

使用onStyleRow应该是这样的

解决方案2,使用格式化器

在你的字段声明中,你应该有

{
    field : 'netchange',
    name : 'netchange',
    width : '30px'
    formatter: formatNetchange
} 

注意,我已经添加了formatNetchange作为格式化器。

然后创建格式化器。

formatNetchange = function(value){
     if(value < 0){
        color = "red";
     } else {
        color = "green";
     }
     return "<span style='color:" + color "'>" + value "</span>";
}

相关内容

  • 没有找到相关文章

最新更新