2014-12-04 176 views
4

我的问题是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

The Result

通常在网格中的细胞应显示列表的计元素在我的商店。

任何人都可以帮助我了解我做错了什么吗?

+0

抱歉坏格式 – FlorianQo 2014-12-04 13:55:49

+1

我不清楚你如何在这里配置您的GridPanel,但显然c是不是你期待它。可能你可以用另一种方式管理'c'? - 您的商店中似乎只有一条记录,因此您可以从传递给渲染器的其他值推断'c'?例如,传递的第四个参数是'rowIndex',第五个参数是'colIndex',所以类似于c =(rowIndex)* 7 + colIndex + 1; (假设你总是连续七天)? – pherris 2014-12-04 15:01:03

+1

我的商店中有更多记录取决于员工数量。在一行中有7天以上。这取决于一个月的长度。 – FlorianQo 2014-12-04 15:09:45

回答

5

的问题是:

在JavaScript中,函数封装这是在一个范围内定义以这样的方式自己之外的变量,他们有一个“活”的参考变量,而不是快照它在任何特定时间的价值。

Understanding variable capture by closures in Javascript/NodeHow do JavaScript closures work?

由于“C”或“计数器”使用“C”被调用的方法之前被完全递增,的“c”的值总是在达到的最高值for循环。要解决此问题,需要在创建渲染器函数时捕获'c'的值。此代码说明了问题,如何捕捉值来达到你想要的效果:

var counter = 0; 
var dayOfMonths = []; 
var dayOfMonthCaptured = []; 
for (var i = 0; i < 10; i++) { 
    var c = counter; 
    console.log(c); 
    dayOfMonths.push(function() { 
    var index = c; 
    //since counter is incremented fully before this method is called, you get the last value 
    console.log(index); 
    }); 
    //here we pass the current value of c to a new function and capture its current value 
    dayOfMonthCaptured.push((function (index) { 
     return function() { 
     console.log(index); 
     }; 
    })(c)); 
    counter++; 
} 
//this won’t work 
for (day in dayOfMonths) { 
    dayOfMonths[day](); 
} 
console.log("—————————"); 
for (day in dayOfMonthCaptured) { 
    dayOfMonthCaptured[day](); 
} 
+1

这是正确的。另一种说法是,c被所有不同的渲染器共享。 – 2014-12-05 02:32:30