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);
    })
})

The Experts

Evan Hicks

Working Code, Happy Users. Sentry Application Monitoring.

Fix Bugs Faster