我正在研究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"
}
]
答案 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);
}
});
结构现在包含我之前描述的数据。