gpt4 book ai didi

Javascript递归函数不起作用

转载 作者:行者123 更新时间:2023-11-30 08:45:48 24 4
gpt4 key购买 nike

我正在尝试编写代码来读取嵌套的 JSON 并打印项目。稍后我打算从中生成一个菜单。

JSON内容如下:

{
"label": "Root of Menu",
"child": [
{
"label": "Menu 1",
"child": [
{
"label": "Menu 1.1",
"child": [
{
"label": "Menu 1.1.1"
},
{
"label": "Menu 1.1.2"
}
]
},
{
"label": "Menu 1.2",
"child": [
{
"label": "Menu 1.2.1"
},
{
"label": "Menu 1.2.2"
}
]
},
{
"label": "Menu 1.3",
"child": [
{
"label": "Menu 1.3.1"
},
{
"label": "Menu 1.3.2"
}
]
}
]
},
{
"label": "Menu 2",
"child": [
{
"label": "Menu 2.1"
},
{
"label": "Menu 2.2"
}
]
},
{
"label": "Menu 3",
"child":
{
"label": "Menu 3.1"
}
}
]
}

我正在使用以下递归函数:

function menuize(m) { 
if (m instanceof Array) {
for(i = 0; i < m.length; i++) {
for(p in m[i]) {
menuize(m[i][p]);
}
}
} else if (m instanceof Object) {
for(p in m) {
menuize (m[p]);
}

} else {
console.log('Label: ' + m);
}

}

menuize(m) 调用以 m 开始,它是使用 JSON.parse(XHR.responseText) 评估的 JSON 对象,其中 XHR 是用于检索数据的 XMLHttpRequest 对象。我已经看到数据读取完全正常,所以这不是问题。

现在,发生的事情是该函数在某种程度上工作正常,因为它在到达最里面的 child 之前工作正常,但在那之后,它就无法返回以正确打印其余部分元素上一级等等。

生成的输出将帮助您了解正在发生的事情:

t: Root of Menu 
t: Menu 1
t: Menu 1.1
t: Menu 1.1.1
t: Menu 1.1.2

我不明白到底发生了什么,为什么不打印Menu 1.2Menu 2(相对上层)之类的项目.

有人可以提供一些见解并帮助我理解吗?谢谢!

最佳答案

您的迭代变量需要使用 var 声明,因此它们将是局部变量。否则,当您递归时,您将覆盖调用者中使用的变量。

function menuize(m) { 
var i, p;
if (m instanceof Array) {
for(i = 0; i < m.length; i++) {
for(p in m[i]) {
menuize(m[i][p]);
}
}
} else if (m instanceof Object) {
for(p in m) {
menuize (m[p]);
}

} else {
console.log('Label: ' + m);
}

}

关于Javascript递归函数不起作用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22125326/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com