嵌套对象的CreateJS Container递归循环

时间:2013-10-04 01:34:35

标签: javascript html5-canvas createjs

我是一名ActionScript开发人员,最终投身于HTML5和JavaScript。我正在使用CreateJS,因为它有一个像我这样的人更容易过渡的声誉。我正在尝试创建一个递归循环,让我知道我在舞台上有什么嵌套对象。我显然不在那里。任何人都可以帮助指出我哪里出错了?谢谢。

recur(exportRoot);

function recur(thisContainer)
{
    console.log("recur()");
    for(var i=0; i<thisContainer.getNumChildren; i++)
    {
        console.log(thisContainer.getChildAt[i]);
        if(thisContainer.getChildAt[i].getNumChildren !== null && thisContainer.getChildAt[i].getNumChildren !== isNaN())
        {
            recur(thisContainer.getChildAt[i]);
        }
    }
}

2 个答案:

答案 0 :(得分:1)

不应使用getNumChildren来查看孩子是否是容器,而应使用此:

var child = thisContainer.getChildAt[i];
if ( child instanceof createjs.Container ) {
    recur(child);
}

更新easeljs-0.8.1:

    private loopContaneir(objDisplay) {
        for (var i= 0; i < objDisplay.numChildren; i++) {
            var child = objDisplay.getChildAt(i);
            if (child instanceof createjs.Container) {
                loopContaneir(child);
            }
        }
    }

答案 1 :(得分:0)

似乎我最大的问题之一是我试图使用getNumChildren(不存在的属性)而不是getNumChildren()(方法)。我现在已经让它正常工作,部分归功于@olsn建议instanceof

recur(exportRoot);

function recur(thisContainer)
{
    console.log("recur()");
    var containerLength = thisContainer.getNumChildren();
    var thisChild;
    for(var i=0; i<containerLength; i++)
    {
        thisChild = thisContainer.getChildAt(i);
        console.log(thisChild);
        if(thisChild instanceof createjs.Container)
        {
            recur(thisChild);
        }
    }
}