Node Ramda + 根据值查找对象
Node Ramda + find the object based on value
可以根据值获取对象吗?
在下面的示例json中,键名有类型,因此需要根据类型值获取结果。
例如,如果 type='user' 则只获取用户对象的结果,而不是员工对象的结果。
我在这里遇到了两个密钥(用户和员工),请问您能否建议如何处理
var list =[
{"doc":{"type":"user","Title":"test1","Relations":{"users":[{"name": "user1"},{"name": "user2"},{"name": "user3"}],"employee":[{"emp": "user2"}]}}},
{"doc":{"type":"employee","Title":"test2","Relations":{"users":[{"name": "user1"}],"employee":[{"name": "emp1"},{"name": "emp2"},{"name": "emp3"}]}}}
];
const getDetails = R.chain(R.pipe(
R.path(['doc', 'Relations']),
R.pick(['users', 'employee']),
R.values
))
const result = getDetails(list)
console.log(result)
<script src="//cdnjs.cloudflare.com/ajax/libs/ramda/0.25.0/ramda.min.js"></script>
当前输出:
[[{"name": "user1"}, {"name": "user2"}, {"name": "user3"}], [{"emp": "user2"}], [{"name": "user1"}], [{"name": "emp1"}, {"name": "emp2"}, {"name": "emp3"}]]
预期输出:
[[{"name": "user1"}, {"name": "user2"}, {"name": "user3"}], [{"name": "emp1"}, {"name": "emp2"}, {"name": "emp3"}]]
您可以使用 R.cond
基于一组谓词来分支逻辑,例如在您的示例中 type
是 user
还是 employee
。
使用这种方法,您需要将 R.chain
切换为 R.map
以匹配您的预期列表,除非您希望对数组进行额外的展平。
const list = [
{"doc":{"type":"user","Title":"test1","Relations":{"users":[{"name": "user1"},{"name": "user2"},{"name": "user3"}],"employee":[{"emp": "user2"}]}}},
{"doc":{"type":"employee","Title":"test2","Relations":{"users":[{"name": "user1"}],"employee":[{"name": "emp1"},{"name": "emp2"},{"name": "emp3"}]}}}
]
const getDetails = R.map(R.pipe(
R.prop('doc'),
R.cond([
[R.propEq('type', 'user'), R.path(['Relations', 'users'])],
[R.propEq('type', 'employee'), R.path(['Relations', 'employee'])]
])
))
const expected = [[{"name": "user1"}, {"name": "user2"}, {"name": "user3"}], [{"name": "emp1"}, {"name": "emp2"}, {"name": "emp3"}]]
console.log(R.equals(expected, getDetails(list)))
<script src="//cdnjs.cloudflare.com/ajax/libs/ramda/0.25.0/ramda.min.js"></script>
可以根据值获取对象吗?
在下面的示例json中,键名有类型,因此需要根据类型值获取结果。
例如,如果 type='user' 则只获取用户对象的结果,而不是员工对象的结果。
我在这里遇到了两个密钥(用户和员工),请问您能否建议如何处理
var list =[
{"doc":{"type":"user","Title":"test1","Relations":{"users":[{"name": "user1"},{"name": "user2"},{"name": "user3"}],"employee":[{"emp": "user2"}]}}},
{"doc":{"type":"employee","Title":"test2","Relations":{"users":[{"name": "user1"}],"employee":[{"name": "emp1"},{"name": "emp2"},{"name": "emp3"}]}}}
];
const getDetails = R.chain(R.pipe(
R.path(['doc', 'Relations']),
R.pick(['users', 'employee']),
R.values
))
const result = getDetails(list)
console.log(result)
<script src="//cdnjs.cloudflare.com/ajax/libs/ramda/0.25.0/ramda.min.js"></script>
当前输出:
[[{"name": "user1"}, {"name": "user2"}, {"name": "user3"}], [{"emp": "user2"}], [{"name": "user1"}], [{"name": "emp1"}, {"name": "emp2"}, {"name": "emp3"}]]
预期输出:
[[{"name": "user1"}, {"name": "user2"}, {"name": "user3"}], [{"name": "emp1"}, {"name": "emp2"}, {"name": "emp3"}]]
您可以使用 R.cond
基于一组谓词来分支逻辑,例如在您的示例中 type
是 user
还是 employee
。
使用这种方法,您需要将 R.chain
切换为 R.map
以匹配您的预期列表,除非您希望对数组进行额外的展平。
const list = [
{"doc":{"type":"user","Title":"test1","Relations":{"users":[{"name": "user1"},{"name": "user2"},{"name": "user3"}],"employee":[{"emp": "user2"}]}}},
{"doc":{"type":"employee","Title":"test2","Relations":{"users":[{"name": "user1"}],"employee":[{"name": "emp1"},{"name": "emp2"},{"name": "emp3"}]}}}
]
const getDetails = R.map(R.pipe(
R.prop('doc'),
R.cond([
[R.propEq('type', 'user'), R.path(['Relations', 'users'])],
[R.propEq('type', 'employee'), R.path(['Relations', 'employee'])]
])
))
const expected = [[{"name": "user1"}, {"name": "user2"}, {"name": "user3"}], [{"name": "emp1"}, {"name": "emp2"}, {"name": "emp3"}]]
console.log(R.equals(expected, getDetails(list)))
<script src="//cdnjs.cloudflare.com/ajax/libs/ramda/0.25.0/ramda.min.js"></script>