我的问题是ExtJS 4中GridPanel中列的渲染器函数。渲染器的记录应该从我的存储中加载列表中的一个元素,并且它会执行;但它始终加载列表中的相同元素。ExtJS列渲染器
这里是我的代码的相关片段。
首先我的商店:
var nStore = Ext.create('Ext.data.Store', {
storeId: 'people',
fields: ['team', 'name', 'liste', 'sums'],
data: [{
team: 'TestTeam', name: 'TestPerson',
liste: ['F', 'F', 'F', 'S', 'N', 'F', 'S',
'S', 'S', 'F', 'F', 'F', 'S', 'A', 'N',
'S', 'S', 'S', 'S', '', '', 'N', 'N',
'N', 'S', 'S', 'N', 'S', 'F', 'N', 'N'],
sums: [[7, 4, 0, 0, 0, 0, 0], [3, 0, 0, 0, 0]]
}]
});
然后我的柱阵列,其中所述渲染器是:
var counter = 0;
for (var i = 0; i < Object.kws.length; i++) {
var DayOfMonth = [];
var DayOfWeek = [];
for (var j = 0; j < Object.kws[i].kwDays.length; j++) {
var c = counter;
DayOfMonth[j] = {
text: '<span style="font-size: 87%;">'
+ Object.kws[i].kwDays[j].day
+ '.<br>'
+ Object.kws[i].kwDays[j].dayOfWeek
+ '.</span>', sortable: false,
draggable: false, menuDisabled: true,
resizable: false, width: 40, align: 'center',
renderer: function (value, meta, record) {
return record.data.liste[c];
}
};
counter++;
}
}
该代码适于和删节。
这里是一个picture of the result:
通常在网格中的细胞应显示列表的计元素在我的商店。
任何人都可以帮助我了解我做错了什么吗?
抱歉坏格式 – FlorianQo 2014-12-04 13:55:49
我不清楚你如何在这里配置您的GridPanel,但显然c是不是你期待它。可能你可以用另一种方式管理'c'? - 您的商店中似乎只有一条记录,因此您可以从传递给渲染器的其他值推断'c'?例如,传递的第四个参数是'rowIndex',第五个参数是'colIndex',所以类似于c =(rowIndex)* 7 + colIndex + 1; (假设你总是连续七天)? – pherris 2014-12-04 15:01:03
我的商店中有更多记录取决于员工数量。在一行中有7天以上。这取决于一个月的长度。 – FlorianQo 2014-12-04 15:09:45