Ramda Js:使用同一对象中的值设置对象的属性

问题描述 投票:3回答:3

使用Ramda Js,我需要创建一个函数,该函数可以使用同一对象上不同属性的值设置一个对象属性。我到目前为止的尝试如下:

var foo = R.set(R.lensProp('bar'), 'foo' + R.prop('foo'));
var result = foo({foo:"bar"});

期望的结果:

{foo:"bar", bar:"foobar"}

实际结果:

{foo:"bar", bar: "foofunction f1(a) {... etc"}

很明显,我在这里误解了一些东西,任何有关如何处理这个问题的见解都会受到赞赏。

javascript ramda.js
3个回答
10
投票

当一个属性的值取决于另一个属性的值时,镜头不适合。一个lambda可能是最好的:

const foo = o => R.assoc('bar', 'foo' + o.foo, o);

foo({foo: 'bar'});
// => {foo: 'bar', bar: 'foobar'}

7
投票

我刚刚编写了类似@davidchambers的答案,然后制作了一个无点版本,只是为了表明lambda实际上有多简单。而不是抛弃它,这是相比它看起来有多糟糕:

var foo = (obj) => R.assoc('bar', 'foo' + obj.foo, obj);
var foo = R.converge(R.assoc('bar'), [R.pipe(R.prop('foo'), R.concat('foo')), R.identity]);

Ramda REPL上有两个中间版本


0
投票

我将问题分为两部分:首先,您需要将对象的foo属性复制到bar,然后更改bar的值。在第一个ramda没有开箱即用的解决方案,但你可以使用evolve作为第二个:

import { curry, assoc, compose, evolve } from 'ramda'

// String -> String -> {k: v}
const copyPropAs = curry((from, to, obj) => assoc(to, obj[from], obj))

// String -> String -> String
const prefix = curry((value, string) => value + string)

const fn = compose(
  evolve({
    foo: prefix('foo')
  }),
  copyPropAs('foo', 'bar')
)

fn({foo: 'bar'})

我知道,这并不是全部都是免费的,但是通过这种方式,有问题的部分被隔离到一个点,在这一点上它不能再被分解成更小的部分,我们总是可以回到那些找到更好的实现。

© www.soinside.com 2019 - 2024. All rights reserved.