通过字符串数组创建具有特定键和值的 JSON 树

如何解决通过字符串数组创建具有特定键和值的 JSON 树

我有一个字符串数组

["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文件或目录)、{{1 }}(实际的数组条目)、pathid(仅当类型为目录时!如果目录中没有任何内容则为空数组)

所以返回的值应该是这样的:

children

所以,我现在有两个大问题:

  1. 使用特定键减少操作对象后返回
  2. 从目录中区分文件

这就是我现在得到的:

[
            {
              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",path: "../../elements/storage/UI",children: [
                {
                  id: 4,name: "Model",path: "../../elements/storage/UI/Model",children: [
                    {
                      id: 5,name: "viewmodel",path: "../../elements/storage/UI/Model/viewmodel",children: [],{
                  id: 6,name: "elements",path: "../../elements/storage/elements",{
                  id: 7,name: "i18n",path: "../../elements/storage/i18n",{
                  id: 8,name: "index.template.html",path: "../../elements/storage/index.template.html",{
              id: 9,name: "DeviceConnector",path: "../../elements/storage/DeviceConnector",]

解决方法

您可以使用最后一个斜杠并使用它来更改类型。

const
    data = ["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"],result = data.reduce((r,path) => {
        path.split('\/').reduce((level,name) => {
            if (name === '') {
                level.type = 'directory';
                return;
            }
            let directory = (level.children = level.children || []).find(q => q.name === name);
            if (!directory) level.children.push(directory = { id: '_' + Math.random().toString(36).substr(2,9),name,type: 'file',path });
            return directory;
        },r);
        return r;
    },{}).children;

console.log(result);
.as-console-wrapper { max-height: 100% !important; top: 0; }

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?
Java在半透明框架/面板/组件上重新绘画。
Java“ Class.forName()”和“ Class.forName()。newInstance()”之间有什么区别?
在此环境中不提供编译器。也许是在JRE而不是JDK上运行?
Java用相同的方法在一个类中实现两个接口。哪种接口方法被覆盖?
Java 什么是Runtime.getRuntime()。totalMemory()和freeMemory()?
java.library.path中的java.lang.UnsatisfiedLinkError否*****。dll
JavaFX“位置是必需的。” 即使在同一包装中
Java 导入两个具有相同名称的类。怎么处理?
Java 是否应该在HttpServletResponse.getOutputStream()/。getWriter()上调用.close()?
Java RegEx元字符(。)和普通点?