Javascript看似存在的对象

时间:2013-07-30 12:22:42

标签: javascript console.log

不幸的是,我无法轻松粘贴生成变量的整个脚本,但我认为它也不相关。如有必要,请指示更多详细信息。

Javascript显示了这一点:

console.log(gl.boxes);

所示:

[{element:{0:{jQuery19104057279333682955:9}, context:{jQuery19104057279333682955:9}, length:1}, boxName:"testi1", boxX:1, boxY:"180"}]

所以gl.boxes[0]应该存在,对吗?仍然...

console.log(gl.boxes[0])

显示:undefined。

那么我可以在这里找到什么?

编辑: 我将粘贴一些关于gl.boxes生成的代码。应该主要是首先将变量创建为数组:

gl.boxes = [];

然后有一个处理创建和推送新对象的函数:

this.addBox = function (box) {
    var retBox = {};
    retBox.element = $(document.createElement('div'));

    retBox.boxName = box.boxName;
    retBox.boxX = box.boxX ? box.boxX : rootParent.defaultX;
    retBox.boxY = box.boxY ? box.boxY : rootParent.defaultY;

    retBox.element
            .html(retBox.boxName)
            .addClass(rootParent.boxClass)
            .offset({ left: retBox.boxX, top: retBox.boxY })
            .draggable({
                stop: gl.URLs.dragStopDiv(retBox)
            });
    retBox.element.appendTo(rootParent.containerDiv);
    gl.boxes.push(retBox);
    return retBox;
};

根据URL创建对象。 IE浏览器。在这个测试中我有内联JS:

gl.objects.addBox({"boxName":"testi1","boxX":"50","boxY":"180"});

只有使用gl.boxes的其他地方才会根据对象生成URL:

for(key in gl.boxes) {
    var position = gl.boxes[key].element.position();

    uri += 
        "boxName["+key+"]="+gl.boxes[key].boxName+"&"+
        "boxX["+key+"]="+position.left+"&"+
        "boxY["+key+"]="+position.top+"&";
}

1 个答案:

答案 0 :(得分:0)

也许您需要更改循环以使用索引:

var i = 0,
    position = {};

for (i = 0; i < gl.box.length; i += 1) {
    position = gl.boxes[i].element.position();
    uri += "boxName[" + i + "]=" + gl.boxes[i].boxName + "&" + "boxX[" + i + "]=" + position.left + "&" + "boxY[" + i + "]=" + position.top + "&";
}