首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >递归材料名称打印逻辑

递归材料名称打印逻辑
EN

Code Review用户
提问于 2015-01-17 11:41:47
回答 1查看 86关注 0票数 2

我有一个函数,它遍历对象中的每个名称。该对象具有一个数组参数materials,该参数包含其他对象。这些对象具有相同的数组参数,这些数组参数包含更多的对象,等等。

我的代码行3-5只是重复添加.material和另一个变量。此外,代码将只进入一个对象的名称,向下四层,否则,我必须继续重复更多的代码。

我怎么才能减少这个烂摊子呢?

代码语言:javascript
复制
var itemList = function(x) {
    console.log(x.materials[0].name);
    for (var i = 1; i < x.materials.length; i++) {
    console.log(x.materials[i].name);
       if (x.materials[i].build !== "BasicFactory" && i !== 0) {
           for (var j = 1; j < x.materials[i].materials.length; j++) {
               console.log(x.materials[i].materials[j].name);
               if (x.materials[i].materials[j].build !== "BasicFactory" && j !== 0) {
                   for (var k = 1; k < x.materials[i].materials[j].materials.length; k++) {
                   console.log(x.materials[i].materials[j].materials[k].name);
                   if (x.materials[i].materials[j].materials[k].build !== "BasicFactory" && j !== 0) {
                       for (var l = 1; l < x.materials[i].materials[j].materials[k].materials.length; l++) {
                       console.log(x.materials[i].materials[j].materials[k].materials[l].name);
                    }
                }
              }
            }
        }
    }
}
};
EN

回答 1

Code Review用户

发布于 2015-01-17 11:49:17

您可以对itemList中的每个对象递归调用x.materials

代码语言:javascript
复制
var itemList = function(x) {
    for (var i = 0; i < x.materials.length; i++) {
        console.log(x.materials[i].name);
        if (x.materials[i].build !== "BasicFactory" && i !==0) {
            itemList(x.materials[i]);
        }
    }
};
票数 4
EN
页面原文内容由Code Review提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://codereview.stackexchange.com/questions/77797

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档