Problems When Using 'for-in' with Arrays

Evan Hicks

The Problem

The for-in operator in Node and JS itself is a little misleading and can cause hard to debug issues if you don’t understand the gotchas when using it. Certainly for-in should never be used when iterating over an Array. This is because for-in is not actually guaranteed to return the properties in the correct order. That can be an especially large problem when iterating over an Array.

The Solution

Node/JS are blessed with lots of different solutions for this problem. The first is the for-of operator, which actually returns the values of the array itself and guaranteed to be in the correct order.

const a = [1, 2, 3]; for (let x of a) { console.log(x); } // 1 // 2 // 3

There is also the Array.forEach method, and it’s related helper functions like some and every.

a.forEach((x, idx) => { console.log(idx, x); });

However, sometimes the simplest solution is best, using a basic for loop. This has some added utility, such as being a little easier to break out of, and allowing for functionality like looping in reverse. If you initialize your variables with let in the for loop itself, then there is the additional benefit of having those values closed within their particular run through the loop. That makes examples below possible, as each listener will be bound with the correct value.

for (let i = 0; i < a.length; i++) { someElement.addEventListener('click', e => { console.log('i is', i); }) })

Further Reading

If you’re looking to get a deeper understanding of how Node.js application monitoring works, take a look at the following articles:

Get Started With Sentry

Get actionable, code-level insights to resolve Node performance bottlenecks and errors.

  1. Create a free Sentry account

  2. Create a Node project and note your DSN

  3. Install the Sentry Node SDK

npm install @sentry/node
  1. Configure your DSN
const Sentry = require('@sentry/node'); Sentry.init({ dsn: 'https://<key>@sentry.io/<project>' });

Loved by over 4 million developers and more than 90,000 organizations worldwide, Sentry provides code-level observability to many of the world’s best-known companies like Disney, Peloton, Cloudflare, Eventbrite, Slack, Supercell, and Rockstar Games. Each month we process billions of exceptions from the most popular products on the internet.

Share on Twitter
Bookmark this page
Ask a questionJoin the discussion

Related Answers

A better experience for your users. An easier life for your developers.

    TwitterGitHubDribbbleLinkedinDiscord
© 2024 • Sentry is a registered Trademark
of Functional Software, Inc.