【发布时间】:2021-07-11 11:13:30
【问题描述】:
我有一个字符串数组
["storage/", "storage/ui/", "storage/inventory/", "storage/model/", "storage/staticmos/", "storage/ui/server.js", "storage/ui/config.js", "storage/ui/elements/", "storage/ui/package.json", "storage/ui/model/", "storage/ui/gulpfile.js", "storage/ui/i18n/", "storage/ui/metadata/", "storage/ui/index.template.html"]
我的目的是创建一个 json 树,其中每个对象都将包含下一个属性:name(目录名/文件名)、type(文件或目录)、path(实际数组entry), id, children (仅当类型为目录时!如果目录中没有任何内容则为空数组)
所以返回的值应该是这样的:
[
{
id: 1,
name: "Inventory",
type: "directory",
path: "../../elements/storage/Inventory",
children: [
{
id: 2,
name: "inventory.yaml",
type: "file",
path: "../../elements/storage/Inventory/inventory.yaml",
},
],
},
{
id: 3,
name: "UI",
type: "directory",
path: "../../elements/storage/UI",
children: [
{
id: 4,
name: "Model",
type: "directory",
path: "../../elements/storage/UI/Model",
children: [
{
id: 5,
name: "viewmodel",
type: "directory",
path: "../../elements/storage/UI/Model/viewmodel",
children: [],
},
],
},
{
id: 6,
name: "elements",
type: "directory",
path: "../../elements/storage/elements",
children: [],
},
{
id: 7,
name: "i18n",
type: "directory",
path: "../../elements/storage/i18n",
children: [],
},
{
id: 8,
name: "index.template.html",
type: "file",
path: "../../elements/storage/index.template.html",
},
],
},
{
id: 9,
name: "DeviceConnector",
type: "directory",
path: "../../elements/storage/DeviceConnector",
children: [],
},
]
所以,我现在有两个大问题:
- reduce 操作对象后返回特定键
- 从目录中区分文件。
这是我现在得到的:
createObject([...pathes]) {
return pathes.reduce((obj, path) => {
// eslint-disable-next-line no-return-assign
path.split('/').reduce((obj, key) => {"id":'_' + Math.random().toString(36).substr(2, 9),"name":obj[key],"path":path} , obj);
return obj;
}, []);
}
【问题讨论】:
标签: javascript arrays json object reduce