码迷,mamicode.com
首页 > Web开发 > 详细

Ext-js处理loadData的问题

时间:2014-12-25 18:17:28      阅读:117      评论:0      收藏:0      [点我收藏+]

标签:

昨天跟踪代码发现在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的问题

标签:

原文地址:http://www.cnblogs.com/ling00218077/p/4185099.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!