functional-programming - Ramda applySpec - 保留未修改的道具
问题描述
假设我有一个对象const foo = { a: 1, b: 2 }
,我想添加一个基于 b 的道具 c。
我可以:
applySpec({
a: prop('a'),
b: prop('b'),
c: ({ b }) => b + 1
}, foo)
并得到一个像这样的对象:{ a: 1, b: 2, c: 3 }
有没有更好的方法来做到这一点?
我查看了evolve、assoc 和applySpec,但它们似乎都不适合目的。
解决方案
您可以使用 R.chain 创建一个应用规范的函数,然后将新对象与原始对象合并。
如果 R.chain 与函数 ( f
& g
) 一起使用:
chain(f, g)(x)
相当于f(g(x), x)
在这种情况下chain(mergeLeft, applySpec({}))
等于mergeLeft(applySpec({}), originalObject)
。
const { chain, mergeLeft, applySpec } = R
const fn = chain(mergeLeft, applySpec({
c: ({ b }) => b + 1
}))
const foo = { a: 1, b: 2 }
const result = fn(foo)
console.log(result)
<script src="https://cdnjs.cloudflare.com/ajax/libs/ramda/0.27.1/ramda.min.js" integrity="sha512-rZHvUXcc1zWKsxm7rJ8lVQuIr1oOmm7cShlvpV0gWf0RvbcJN6x96al/Rp2L2BI4a4ZkT2/YfVe/8YvB2UHzQw==" crossorigin="anonymous"></script>
您可以通过使用 R.pipe 将 curried R.applySpec 传递给链来使其成为允许添加到现有对象的通用函数:
const { pipe, chain, mergeLeft, applySpec } = R
const fn = pipe(applySpec, chain(mergeLeft))
const addCProp = fn({
c: ({ b }) => b + 1
})
const foo = { a: 1, b: 2 }
const result = addCProp(foo)
console.log(result)
<script src="https://cdnjs.cloudflare.com/ajax/libs/ramda/0.27.1/ramda.min.js" integrity="sha512-rZHvUXcc1zWKsxm7rJ8lVQuIr1oOmm7cShlvpV0gWf0RvbcJN6x96al/Rp2L2BI4a4ZkT2/YfVe/8YvB2UHzQw==" crossorigin="anonymous"></script>
推荐阅读
- maven - Sonar 可以排除 Maven 项目之外的文件吗?另外,它可以排除Java以外的文件吗?
- python - 没有火车和测试拆分的第二天预测
- javascript - 获取 Google 自动广告小插曲的元素 - 嵌套文档 [已编辑]
- javascript - 重复 HTML 画布元素(框)以填充整个视口
- xml - VBA:查找和替换 XML 节点
- arrays - 垂直跨行的数组元素的 MIN/MAX
- android - 可重用的机制来监听 LiveData 在 Android 中的特定错误
- javascript - 模态对话框上闪亮的 dateInput 日历不会随着页面滚动而移动
- sql - 基于另一个表中的行的计算列
- python - Pandas:如何检查数据框中的所有行是否仅针对两列加起来为 100?