我hava使用dojo实现了一个datagrid,每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'
} ];
答案 0 :(得分:5)
在我回答这个问题之前,当你说“动态更改单元格格式”时,只是一个微不足道的误解。
您没有更改单元格formatter
,而是更改单元格的样式。
每次将值加载到单元格中时,都会调用格式化程序。此外,为单元格所在的行调用onStyleROw函数。
这意味着您有两个选项可用于更改单元格的颜色。您可以在单元格范围内执行此操作,或者您可以让格式化程序执行一些简单的操作,例如使用具有不同样式颜色的<span>
包装值。我会告诉你们两个。
这是第一个不改变任何现有网格代码的解决方案,它将使用onStyleRow更改整行。
dojo.connect(grid4,“onStyleRow”,styleRowGridPayment);
styleRowGridPayment
方法。)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。
在您的字段声明中,您将拥有
{
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>";
}