Follow

Keep Up to Date with the Most Important News

By pressing the Subscribe button, you confirm that you have read and are agreeing to our Privacy Policy and Terms of Use
Contact

How to manipulate array of objects without loop

I have a code like below and it is working fine.

 for(let i=0;i< this.Array.length ; i++){
          if(this.Array[i].propertyObject.hasOwnProperty('header'))
          this.Array[i].ColumnName = this.Array[i].propertyObject.header;
    }

May i know how to achieve the same with Map. Thanks in advance.

MEDevel.com: Open-source for Healthcare and Education

Collecting and validating open-source software for healthcare, education, enterprise, development, medical imaging, medical records, and digital pathology.

Visit Medevel

>Solution :

May i know how to achieve the same with Map

I assume you mean map. map isn’t the right tool for doing exactly what that loop does, because that loop modifies the array in place, but map creates a new array instead.

If you want a new array, perhaps also with new objects (e.g., functional programming or immutable programming):

// Replace `this.Array` with a new array
this.Array = this.Array.map(element => {
    // If we need to change this element...
    if (element.propertyObject.hasOwnProperty("header")) {
        // ...do a shallow copy along with the replacement
        element = {...element, ColumnName: element.propertyObject.header};
    }
    return element;
});

Note that that assumes the elements are simple objects. If they aren’t, you’ll need to handle constructing the replacement differently than just using {...original}.

But if you want to keep the same array as your current code does, your loop is just fine. You have other options (like forEach or for-of), but what you have is also fine. for-of is well-suited to what you’re doing:

for (const element of this.Array) {
    if (element.propertyObject.hasOwnProperty("header")) {
          element.ColumnName = element.propertyObject.header;
    }
}

Side note: In new code, you might want to use Object.hasOwn rather than Object.prototype.hasOwnProperty (with a polyfill if needed for older environments; recent versions of all modern browsers support it natively, though).

Add a comment

Leave a Reply

Keep Up to Date with the Most Important News

By pressing the Subscribe button, you confirm that you have read and are agreeing to our Privacy Policy and Terms of Use

Discover more from Dev solutions

Subscribe now to keep reading and get access to the full archive.

Continue reading