最新消息:雨落星辰是一个专注网站SEO优化、网站SEO诊断、搜索引擎研究、网络营销推广、网站策划运营及站长类的自媒体原创博客

javascript - How to destructure an object based on a dynamic defined variable - Stack Overflow

programmeradmin1浏览0评论

I am working with an immutable object that I need to add subtract an array of values from.

I know it's possible using ES6 destructing with the following.

const {countries, remainder} = someObj // {countries:...,languages:..., ...keys};

This will end me up with the remainder being the new Object without the countries key.

Therefore I figured out that I could use reduce on an array to go through and remove all the values from the object, returning a new object in the end, using the default parameter, being the original object.

However, I am not sure how to go about it, because the names of keys are defined in the array.

arrayToRemove.reduce((total, value) => {
  const { extractValue: [value], ...remainder } = total
  return remainder;
}, { ...originalObj });

arrayToRemove.reduce((total, value) => {
  const { [extractValue], ...remainder } = total
  return remainder;
}, { ...originalObj });

I am expecting to end up with a new Object without the keys that are contained in the array called arrayToRemove.

I need to do this while maintaining immutability, so I cannot just loop through the original object and remove them from it, so I thought the above would be a bright way to go about it.

Any help is appreciated.

I am working with an immutable object that I need to add subtract an array of values from.

I know it's possible using ES6 destructing with the following.

const {countries, remainder} = someObj // {countries:...,languages:..., ...keys};

This will end me up with the remainder being the new Object without the countries key.

Therefore I figured out that I could use reduce on an array to go through and remove all the values from the object, returning a new object in the end, using the default parameter, being the original object.

However, I am not sure how to go about it, because the names of keys are defined in the array.

arrayToRemove.reduce((total, value) => {
  const { extractValue: [value], ...remainder } = total
  return remainder;
}, { ...originalObj });

arrayToRemove.reduce((total, value) => {
  const { [extractValue], ...remainder } = total
  return remainder;
}, { ...originalObj });

I am expecting to end up with a new Object without the keys that are contained in the array called arrayToRemove.

I need to do this while maintaining immutability, so I cannot just loop through the original object and remove them from it, so I thought the above would be a bright way to go about it.

Any help is appreciated.

Share Improve this question edited Jan 6, 2019 at 19:31 Serkan Sipahi 6916 silver badges19 bronze badges asked Jan 6, 2019 at 18:59 Vincent RyeVincent Rye 4521 gold badge4 silver badges13 bronze badges 5
  • 1 do you have some data to test ... and the wanted result? – Nina Scholz Commented Jan 6, 2019 at 19:02
  • const originalObj = {countries:[], language:"",food:[],drinks:[]} const arrayToRemove = ["countries","food"] const newObj = arrayToRemove.reduce((total, value) => { const { extractValue: [value], ...remainder } = total return remainder }, { ...originalObj }) – Vincent Rye Commented Jan 6, 2019 at 19:04
  • 1 You need to use ...remainder to get the rest of the object properties. – Cameron Martin Commented Jan 6, 2019 at 19:04
  • as exampled in the above code example, I am using ...remainder, the problem is that I need to extract one key from it, so ...remainder contains only the remainder – Vincent Rye Commented Jan 6, 2019 at 19:06
  • "I need to do this while maintaining immutability, so I cannot just loop through the original object and remove them from it" How about let result = {}; for(let key in originalObj) if(!arrayToRemove.includes(key)) result[key] = originalObj[key]; The downside of the solution using object destructuring is that for each property you "remove" you create a new object where all the remaining properties are copied to. And all, except for the last of these objects, are immediately thrown away. – Thomas Commented Jan 6, 2019 at 19:55
Add a ment  | 

2 Answers 2

Reset to default 9

You could use a puted property names with a dummy as target property.

Read more here: object property assignment pattern [YDKJS: ES6 & Beyond]

var originalObj = { foo: 1, bar: 2, baz: 3, },
    arrayToRemove = ['foo', 'bar'],
    result = arrayToRemove.reduce((total, key) => {
        const { [key]: dummy, ...remainder } = total;
        return remainder;
    }, originalObj);


console.log(result);

arrayToRemove.reduce((obj, key) => {
  const { [key]: value, ...remainder } = obj
  return remainder
}, originalObj)
发布评论

评论列表(0)

  1. 暂无评论