我目前的数据结构大致如下:
var data = { "id": 123,
"modules": [{
"id": 1,
"results": [{
"status": "fail",
"issues": [
{"type": "change", "status": "warn", "data": {}},
{"type": "remove", "status": "warn", "data": {}},
{"type": "change", "status": "warn", "data": {}}
]
}]
},{
"id": 2
"results": [{
"status": "pass",
"issues": [
{"type": "change", "status": "warn", "data": {}},
{"type": "remove", "status": "warn", "data": {}},
{"type": "change", "status": "warn", "data": {}}
]
}]
}]
}
我一直在尝试使用Ramda创建一个可以执行类似操作的撰写查询,更改某些类型的所有问题的状态。
我一直试图通过R.map/R.chain来构建镜头,但我似乎无法解决这个问题。这样的事情就是我想要做的事情:
let approvedData = R.compose(
R.set(R.__, 'approve', Data)
R.lensProp('status')
R.map(R.lensIndex),
R.lensProp('issues'),
R.map(R.lensIndex),
R.lensProp('results'),
R.map(R.lensIndex),
R.lensProp('modules')
)(Data)
让它返回完整数据集并更改状态。
更新
我已经提出了一些能够完成我想要做的事情的代码,但是我仍然在努力将每个步骤变成可以编写的函数:
R.over(R.lensProp('modules'), R.map(
R.over(R.lensProp('results'), R.map(
R.over(R.lensProp('issues'), R.map(
R.set(R.lensProp('status'), 'approve')
))
))
), Data)
答案 0 :(得分:4)
您的更新解决方案对我来说很合适,但可以通过合成创建转换功能:
// update$modules$results$issues$status :: (String -> String) -> Object -> Object
var update$modules$results$issues$status = R.compose(
R.over(R.lensProp('modules')),
R.map,
R.over(R.lensProp('results')),
R.map,
R.over(R.lensProp('issues')),
R.map,
R.over(R.lensProp('status'))
);
update$modules$results$issues$status(R.always('approve'))(data);
答案 1 :(得分:3)
看起来你可能对数组中值的转换感到怀疑。
现在,数据为
const data = {
"id": 123,
"modules": [{
"id": 1,
"results": [{
"status": "fail",
"issues": [
{"type": "change", "status": "warn", "data": {}},
{"type": "remove", "status": "warn", "data": {}},
{"type": "change", "status": "warn", "data": {}}
]
}]
},{
"id": 2,
"results": [{
"status": "pass",
"issues": [
{"type": "change", "status": "warn", "data": {}},
{"type": "remove", "status": "warn", "data": {}},
{"type": "change", "status": "warn", "data": {}}
]
}]
}]
};
您要做的是为每个包含数组的键创建镜头。在您的具体情况下,它们是modules
,results
和issues
。
最重要的是,您需要一个镜头来修改您要修改的密钥,即status
。
所以:
const modulesLens = lensProp('modules')
const resultsLens = lensProp('results')
const issuesLens = lensProp('issues')
const statusLens = lensProp('status')
现在,有了这些,你所要做的就是把它们放在一起。 (我把它们分解以便于理解)
const approveIssues = over(
modulesLens,
map(over(
resultsLens,
map(over(
issuesLens,
map(set(statusLens, 'approve'))
))
))
)
现在剩下要做的就是向approvedIssues
提供您要转换的数据,这是我们的data
。
所以,最后。
//Running this
const approvedData = approveIssues(data)
/* Outputs this
{
"id": 123,
"modules": [{
"id": 1,
"results": [{
"issues": [
{"data": {}, "status": "approve", "type": "change"},
{"data": {}, "status": "approve", "type": "remove"},
{"data": {}, "status": "approve", "type": "change"}
],
"status": "fail"
}]}, {
"id": 2,
"results": [{
"issues": [
{"data": {}, "status": "approve", "type": "change"},
{"data": {}, "status": "approve", "type": "remove"},
{"data": {}, "status": "approve", "type": "change"}],
"status": "pass"
}]}
]}
*/
在这种情况下,我不一定要使用compose
,但我认为这也是可能的。