deepMapKeys
Глубокие карты ключей объекта.
Создает объект с теми же значениями, что и предоставленный объект, и ключи, генерируемые запуском предусмотренной функции для каждого ключа. Используйте Object.keys(obj)
для итерации над ключами объекта. Используйте Array.prototype.reduce(
) для создания нового объекта с теми же значениями и отображаемыми ключами, используя fn
.
const deepMapKeys = (obj, fn) =>
Array.isArray(obj)
? obj.map(val => deepMapKeys(val, fn))
: typeof obj === 'object'
? Object.keys(obj).reduce((acc, current) => {
const key = fn(current);
const val = obj[current];
acc[key] =
val !== null && typeof val === 'object' ? deepMapKeys(val, fn) : val;
return acc;
}, {})
: obj;
EXAMPLES
const obj = {
foo: '1',
nested: {
child: {
withArray: [
{
grandChild: ['hello']
}
]
}
}
};
const upperKeysObj = deepMapKeys(obj, key => key.toUpperCase());
/*
{
"FOO":"1",
"NESTED":{
"CHILD":{
"WITHARRAY":[
{
"GRANDCHILD":[ 'hello' ]
}
]
}
}
}
*/
Опубликовано 3 апреля 2020 в 15:59 (обновлено 23 мая 2023 в 15:39)
3 апреля 2020 в 15:59