如何将路径数组转换为树对象?

时间:2019-01-29 15:48:52

标签: javascript node.js typescript

我想将文件和文件夹路径的数组转换为树对象(下面是对象的数组,子对象指向自身的数组):

type TreeItem<T> = {
  title: T
  key: T
  type: 'tree' | 'blob'
  children: Array<TreeItem<T>>
}

文件和文件夹路径来自“ git ls-tree -r -t HEAD”命令,该命令列出了git存储库的树对象,如下所示:

100644 blob 68afe6febb3f4ab2155b436e2e5a43f62399388b    LICENSE
100644 blob 78d926deaf73e93c12257d0be9dc10f39662aad0    README.md
040000 tree eefd18d086bb6089a4e392bda3105fd32399146b    app
100644 blob 631e6d753849db0ed05d0124ab62c8e5522f1c32    app/.npmrc
100644 blob 72da957f1fec5b3dec8e89e9ab9364bb96a929b0    app/.yarnrc
100644 blob cb66e81274ca308805350d8c1ccc68811994ed1c    app/app-info.ts
100644 blob 1bf399b381dab7c260c1dc4126025c7ab1a437af    app/git-info.ts
100644 blob ec6e40fb46f6554d62823e5f27a8743de594acff    app/package-info.ts
100644 blob bf92f9a597bfd8b8e9b2308a4848faa6937f4a1e    app/package.json
040000 tree dd30a6b5ee422a42da4561ea8443ef8a4a82c078    app/src
040000 tree c8473c433cf8ec2a3d9b67171cff665d7176f264    app/src/ask-pass
100644 blob 76adbc48d6d239fd39eab1ea08c8ee2408df3ece    app/src/ask-pass/ask-pass.ts
100644 blob e1de6d753ce44680071ab7c67615e2d81b279c21    app/src/ask-pass/main.ts
...

如您所见,第二栏我可以告诉它是文件还是文件夹。我为上面的文件和文件夹对象定义了以下结构:

interface GitTreeObject {
  readonly type: string
  readonly hash: string
  readonly path: string
}

这意味着我想将Array <'GitTreeObject>转换为Array <'TreeItem>。 有人知道如何实现转换吗?最好由Typescript实现。谢谢。

我的要求与this one类似,并且我尝试引用该问题的答案,但没有成功

1 个答案:

答案 0 :(得分:3)

通过仅使用路径,您可以将它们拆分为一条缩小的路径,直到获得对象为止。在此对象中,您以后可以添加所需的数据。

var data = ['LICENSE', 'README.md', 'app', 'app/.npmrc', 'app/.yarnrc', 'app/app-info.ts', 'app/git-info.ts', 'app/package-info.ts', 'app/package.json', 'app/src', 'app/src/ask-pass', 'app/src/ask-pass/ask-pass.ts', 'app/src/ask-pass/main.ts'],
    result = {};
    
data.forEach(p => p.split('/').reduce((o, k) => o[k] = o[k] || {}, result));

console.log(result);