[英]Group by key value pairs whilst merging duplicates using ramda
我有一系列表单错误,如下所示:
[
{
"path": "email",
"message": "email must be at least 10 characters",
},
{
"path": "email",
"message": "email must be a valid email",
},
{
"path": "password",
"message": "password must be at least 8 characters",
}
]
需要对形状进行转换,使其符合表单的错误API。 我想做的是使用ramda对其进行转换,使其最终结果如下:
{
email: ["email must be at least 10 characters", "email must be a valid email"],
password: ["password must be at least 8 characters"]
}
ramda函数用于实现此目的的最佳选择是什么?
使用R.pipe
(或R.compose
)创建一个按path
属性(通过R.prop
)分组的函数,然后在R.map
使用R.pluck
获取每个组中的message
属性:
const { pipe, groupBy, prop, map, pluck } = R const fn = pipe( groupBy(prop('path')), map(pluck('message')) ) const data = [{"path":"email","message":"email must be at least 10 characters"},{"path":"email","message":"email must be a valid email"},{"path":"password","message":"password must be at least 8 characters"}] const result = fn(data) console.log(result)
<script src="https://cdnjs.cloudflare.com/ajax/libs/ramda/0.26.1/ramda.js"></script>
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.