我有一个具有数组属性{ property: [a, b] }
的对象,我希望有一个重复对象的列表[{ property: [a] }, { property: [b] }]
输入是:
const input = {
url: 'getting-started',
locales: ['en-GB', 'en-JP']
}
预期表格是:
const expected = [{
url: 'getting-started',
locales: ['en-GB']
}, {
url: 'getting-started',
locales: ['en-JP']
}]
我写的函数有点难以理解,甚至不是纯粹的:
const duplicateByLocales = article => R.pipe(
R.prop('locales'),
R.invert,
R.mapObjIndexed((val, locale) =>
R.pipe(
R.clone,
R.assoc('locales', R.of(locale))
)(article)),
R.values
)(article)
它确实有效,但我很好奇有什么更好的方式?谢谢!
答案 0 :(得分:5)
您可以这样做:
const input = {
url: 'getting-started',
locales: ['en-GB', 'en-JP']
}
let result = input.locales.map(locale => ({...input, locales:[locale]}));
console.log(result);

请注意,{...input}
会创建input
的浅表副本。如果input
有多个级别,则会变得更复杂。
我们可以为它编写一个函数
const transform = input =>
input.locales.map(locale => ({...input, locales:[locale]}))
console.log(transform({
url: 'getting-started',
locales: ['en-GB', 'en-JP']
}))