昨天跟踪代码发现在Ext-js的loadData函数有点小bug:
1 for (var i = 0; i < root.length; i++) {
2 var n = root[i];
3 var values = {};
4 var id = ((sid || sid === 0) && n[sid] !== undefined && n[sid] !== "" ? n[sid] : null);
5 for (var j = 0, jlen = fields.length; j < jlen; j++) {
6 var f = fields.items[j];
7 var k = f.mapping !== undefined && f.mapping !== null ? f.mapping : j;
8 var v = n[k] !== undefined ? n[k] : f.defaultValue;
9 v = f.convert(v, n);
10 values[f.name] = v;
11 }
......
}
其中root就是传进去的要加载的数组,若数组中存在一个undefined元素,
则会在第二行n = root[i];执行后 n=undefined;然后在第8行报错。
这里应该先判断元素是否正常的,因此觉得ext-js处理时,可能对于这种特殊情况考虑不周全。
所以,我们应该自己做数据的时候尽量避免出现这种情况(即
昨天跟踪代码发现在Ext-js的loadData函数有点小bug:
1 for (var i = 0; i < root.length; i++) {
2 var n = root[i];
3 var values = {};
4 var id = ((sid || sid === 0) && n[sid] !== undefined && n[sid] !== "" ? n[sid] : null);
5 for (var j = 0, jlen = fields.length; j < jlen; j++) {
6 var f = fields.items[j];
7 var k = f.mapping !== undefined && f.mapping !== null ? f.mapping : j;
8 var v = n[k] !== undefined ? n[k] : f.defaultValue;
9 v = f.convert(v, n);
10 values[f.name] = v;
11 }
......
}
其中root就是传进去的要加载的数组,若数组中存在一个undefined元素,
则会在第二行n = root[i];执行后 n=undefined;然后在第8行报错。
这里应该先判断元素是否正常的,因此觉得ext-js处理时,可能对于这种特殊情况考虑不周全。
所以,我们应该自己做数据的时候尽量避免出现这种情况(即在上一篇文章中提到的情况),或者应该增加相应的代码处理。
中所述情况),或者应该增加相应的代码处理。