首页 > 代码库 > Ext-js处理loadData的问题

Ext-js处理loadData的问题

昨天跟踪代码发现在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处理时,可能对于这种特殊情况考虑不周全。

 

所以,我们应该自己做数据的时候尽量避免出现这种情况(即在上一篇文章中提到的情况),或者应该增加相应的代码处理。

中所述情况),或者应该增加相应的代码处理。

Ext-js处理loadData的问题