zoukankan      html  css  js  c++  java
  • 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处理时,可能对于这种特殊情况考虑不周全。

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

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

  • 相关阅读:
    数据库遇到的2个奇葩的事情
    虚IP解决程序连只读服务器故障漂移
    SQL Server 主库DML操作慢故障处理过程
    优雅地使用pt-archiver进行数据归档(转)
    Mysql表读写、索引等操作的sql语句效率优化问题
    MySQL Performance-Schema(一) 配置篇
    MySQL Performance-Schema(三) 实践篇
    MySQL Performance-Schema(二) 理论篇
    MySQL案例-并行复制乱序提交引起的同步异常
    (转)MySQL- 5.7 sys schema笔记,mysql-schema
  • 原文地址:https://www.cnblogs.com/ling00218077/p/4185099.html
Copyright © 2011-2022 走看看