将json数组作为类别和子类别的新数组

时间:2018-03-14 14:20:23

标签: javascript json typescript django-rest-framework

我正在研究django rest和angular这个json数组来自服务器ic包含category和subCategory值。 我试图建立一个动态导航栏,所以我想安排这样的数据 [ [web development] : ["subCat1","subcat2",....] [android development] : ["subCat1","subcat2",....] ] 访问类别及其相关的子类

我尝试过这样的事情:但它只设置键和值是安全的

  public categories = [[], [], [], []];
  public data;
      for (let i = 0; i < this.data.length; i++) {


        if (this.data[i].cat_id != null) {
          this.categories[i][this.data[i].title] = [];


        }
        if (this.data[i].parent_id != null && this.data[i].parent_id == this.data[i].cat_id) {
          this.categories[i][this.data[i].title] = [this.data[i].title]
        }


      }

其服务器响应

  [
        {
            "id": 5,
            "cat_id": 0,
            "parent_id": null,
            "title": "web development"
        },
        {
            "id": 6,
            "cat_id": 1,
            "parent_id": null,
            "title": "android development"
        },
        {
            "id": 7,
            "cat_id": null,
            "parent_id": 0,
            "title": "php"
        },
        {
            "id": 8,
            "cat_id": null,
            "parent_id": 1,
            "title": "java"
        }
    ]

2 个答案:

答案 0 :(得分:1)

这里有一些代码可以做你想要的:

interface Categories {
    [title: string]: string[]
}

let categories: Categories = {};

data.filter(c => c.parent_id === null).map(c => <{ title: string; subcategories: string[] }>{
    title: c.title,
    subcategories: data.filter(sc => sc.parent_id === c.cat_id).map(sc => sc.title)
}).forEach(c => {
    categories[c.title] = c.subcategories;
});

console.log(categories);

如您所见,我定义了一个界面。然后我创建一个包含标题及其子类别的对象的时间数组。之后,我将这个结构变成了你需要的东西。

输出结果为:

{
    "web development": ["php"],
    "android development": ["java"]
}

答案 1 :(得分:0)

我不知道我是否理解正确。 我假设“data”变量包含JSON,预期输出将是:

{
    "web development": ["php"],
    "android development": ["java"]
}

这可以通过首先创建“类别”对象来实现,该对象将用于获取给定“parent_id”的“标题”。

const categories = data.reduce((acc, d) => {
    if (d.parent_id === null) {
        acc[d.cat_id] = d.title
    }

    return acc;
}, {});

然后用

创建结构
const structure = {};

data.forEach((d) => {
    if (d.parent_id === null) {
        structure[d.title] = [];
    } else {
        structure[categories[d.parent_id]].push(d.title);
    }
});

结构现在包含我之前描述的数据。