繁体   English   中英

如何将字符串数组转换为嵌套的 JSON 对象?

[英]How to convert array of string to nested JSON object?

我想在我的前端显示 blob 存储中存在的所有文件和文件夹。 我正在使用 PrimeNG 树组件。 但是,我无法将我的响应转换为 primeNG 所需的格式。

这是实际的响应:

"filenames": [
"/30",
"/mtcagent.log",
"/spe9_xf.rst/bin/sbin/spe9_rgg-prop_ycoer.fbin",
"/spe9_xf.rst/bin/sbin/spe.fbin"
]

预期的:

[
{"label": "30",
"Icon": "pi pi-folder"
},
{
"label": "mtcagent.log",
"Icon": "pi pi-folder"
},
{
"label": "spe9_xf.rst",
"Icon": "pi pi-folder",
"children": [
{
"label": "bin",
"Icon": "pi pi-folder",
"children": [
{
"label": "sbin",
"Icon": "pi pi-folder",
"children": [
{
"label": "spe9_rgg-prop_ycoer.fbin",
"Icon": "pi pi-file",
},
{
"label": "spe.fbin",
"Icon": "pi pi-file",
}
]
}
]
}
]
}
]

到目前为止,这是我的代码:

 var arr = [ "abc.rft", "ccc.rft", "spe9_sgrid_long_rstcreation.rst/bin/sbin/spe9_batch-grid.dat.binfiles" ]; var arrOfObjs = new Array(); for (let i = 0; i < arr.length; i++) { var obj = { "expandedIcon": "pi pi-folder-open", "collapsedIcon": "pi pi-folder" }; obj.label = arr[i]; arrOfObjs.push(obj); } arrOfObjs.forEach(e => { if (e.label.indexOf('/') == -1) { } else { var carray = new Array(); var x = e.label.split('/'); e.label = x[0]; obj.label = e.label; carray.push(obj); console.log('carray', carray) e['children'] = JSON.stringify(carray); console.log('sss', arrOfObjs) } });

您可以使用 .map 高阶函数来执行此操作。

或者也许使用:

JSON.parse(JSON.stringify(carray));

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM