[英]change a prop in list of object in ramda.js
我在JSON中有一个对象数组,想要更改一个值的属性。 例如,假设我有一个唯一的字段, amount
name
, name
props。 我的方法是使用findIndex
或map在列表中找到一个对象,然后将其删除并创建一个新对象并将其推入。 这是好方法吗? 可以推荐更好的方法或功能?
尽管Ramda有许多选择,但Lenses
可能是解决这一问题的规范方法。
const people = [
{id: 1, name: 'fred', age: 28},
{id: 2, name: 'wilma', age: 25},
{id: 3, name: 'barney', age: 27},
{id: 4, name: 'betty', age: 29},
]
const personIdx = name => findIndex(propEq('name', name), people)
const ageLens = idx => lensPath([idx, 'age'])
const wLens = ageLens(personIdx('wilma'))
const newPeople = over(wLens, age => age + 1, people)
//=> [
// {id: 1, name: 'fred', age: 28},
// {id: 2, name: 'wilma', age: 26},
// {id: 3, name: 'barney', age: 27},
// {id: 4, name: 'betty', age: 29},
// ]
请注意,尽管newPeople
是一个全新的对象,但它与现有people
共享尽可能多的共享。 例如, newPeople[3] === people[3] //=> true
。
还要注意,除了使用over
调整此镜头的参数外,我们还可以使用view
来简单地获取值:
view(wLens, people) //=> 25
或者我们可以将其设置为一个固定值set
:
set(wLens, 42, people) //=> new version of `people` with wilma's age at 42
最后,请注意镜头组成。 我们也可以这样写:
const ageLens = idx => compose(lensIndex(idx), lensProp('age')).
镜头组成非常强大。
您可以在Rand REPL上看到这一点。
像这样的东西?
var org =
[
{name:"one",age:1}
,{name:"two",age:2}
]
;
var newArray =
org
.map(
(x,index)=>
index === 1
?Object.assign(
{}
,x
,{name:"new name"}
)
:x
)
;
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.