循环可能是错误的术语,但它描述了我正在尝试的事情。
我想为平面数据提供结构,但我还需要跟踪它来自的数组。
基本上我的规则是(每个数组):
如果级别 1 存在 - 给它name
该项目的,以及typechild
大批。每次出现级别 1 时(即使在同一个数组中),它都应该创建一个新条目。
Inside typechild
,放置级别>1的任何项目
如果不存在 1 级 - 给它name
该项目的,以及typechild
array.
我的代码如下almost在那里,除了它应该在每次看到级别 1 时创建一个数组。我的例子是有意义的:
输入数据
[
{
"title": "Test 1",
"type": [{
"name": "Animal",
"level": 1
},
{
"name": "Food",
"level": 1
},
{
"name": "Chicken",
"level": 3
}
]
},
{
"title": "Test 2",
"type": [{
"name": "Foo",
"level": 2
}]
}
]
注意:动物和食品均为 1 级物品。所以它应该像这样创建两个数组......
所需输出
[
{
name: "Animal",
typechild: [
{
level: 2,
name: "Chicken"
}
]
},
{
name: "Food",
typechild: [
{
level: 2,
name: "Chicken"
}
]
},
{
name: "NoName",
typechild: [
{
level: 2,
name: "Foo"
}
]
}
]
Ramda 尝试(在这里尝试:https://dpaste.de/JQHw https://dpaste.de/JQHw):
const levelEq = (n) => pipe(prop('level'), equals(n));
const topLevel = pipe(prop('type'), find(levelEq(1)));
const topLevelName = pipe(topLevel, propOr('NoName', 'name'));
const extract2ndLevel = pipe(pluck('type'), flatten, filter(levelEq(2)));
const convert = pipe(
groupBy(topLevelName),
map(extract2ndLevel),
map(uniq),
toPairs,
map(zipObj(['name', 'typechild']))
);