考虑下面的代码第一个console.log正确记录图像,您可以在下面的图像中看到它的属性.但是,当我尝试登录一个如果它的属性到控制台,我得到undefined!
console.log(that.data[0].cards); //works -- see image below console.log(that.data[0].cards.E); //undefined console.log(that.data[0].cards['E']); //undefined console.log(that.data[0].cards.hasOwnProperty('E')); //false var test = JSON.stringify(that.data[0]); console.log(test); // {} for( var key in that.data[0].cards ) { console.log('hello????') //doesn't appear in the console } console.log( Object.keys( that.data[0].cards ) ); //[] console.log( that.data[0].cards.propertyIsEnumerable("E") ); //false console.log( that.data[0].cards.__lookupGetter__( "E" ) ); //undefined
控制台中的结果:
任何想法这里发生了什么?那个.data [0]里面的xml属性里面也应该有属性,其实就是这个属性.
FWIW,我在Firebug中得到同样的东西(上面的控制台镜像是Chrome).
解决方法
我已经解决了这个问题.基本上,所讨论的对象(that.data [0] .cards)具有由处理所有必需的XML文件的所有AJAX请求之后运行的函数a()创建的属性.我允许请求异步运行,使用计数器确定成功回调函数,如果a()也应该被调用.
在运行a()后,函数b()应该对该.data [i] .cards执行操作.但是,由于()依赖于异步请求,所以在调用a()之前运行b().所以解决方案只是使a()调用b().
所以这样做是一个很简单的错误.令人困惑的是,将..data [0] .cards记录到控制台的事实告诉我,事实上,卡片对象已经建成,实际上还没有.所以控制台给我提供了不正确的信息 – 至少不清楚.
感谢大家的帮助昨晚! Upvote全部:)