For loop in Javascript and ES6 explained

We all know about for loops in Javascript and we have been using them for a long time as the old way before ES6 introduced its new syntax. In this post we will discuss for loop in Javascript and ES6 with some examples. We will use arrays to accomplish the tasks and explain it in depth.

The old way of for loop

To iterate through an array indexes in Javascript we simply write a for loop using a variable to loop through array indexes and log them:

for ( var index=0;index< myArray.length ;index++){



That still works perfectly. It is a long syntax though. Also remember it is using var to initiate the variable. As explained in this post, let is a better choice in for loops to be used as the variable iterator.

The ES5 Solution

Since ES5 we are able to use the built-in forEach loop that simplifies the syntax somehow but it has a drawback.There is no way to stop or break a forEach() loop other than by throwing an exception. And you cannot return a value either:




The for-in loop

How about a for-in loop. It iterates over array elements just as expected:

for (let index in myArray){ 

  // we use let instead of var here



It was used before in Angular as well but replaced with for-of for different reasons:

For loop was designed for iterating over objects with string keys. The values assigned on this code to index are “0”, “1”, “2′ ,… not actual numbers which is inconvenient.

The forin loop is for looping over object properties(keys) not data.

ES6 Solution: for-of loop

To fix for-in loop problems, ES6 has introduced for-of loop which has this syntax for our example:

for (let value of myArray){



Unlike forEach it works with break, continue and return.

It fixes for-in problems. Also it is for looping over object data like the values in array.

Usages of for-of loop

The for-of loop is not just for arrays but it is for most of array like objects.It works on strings as a sequence of unicode characters:

for ( let char of "my String") {



It also works on DOM NodeList object and the arguments object. Just like with arrays, this makes it a little bit easier to iterate over these non-array objects.

Remember for-of does not work on plain objects.Use for-in fort them or the built-in object.keys() in for-of loop”

for (var key of Object.keys(someObject)) {

  console.log(key + ": " + someObject[key]); 

New  ES6 collections (Map, Set, WeakMap, and WeakSet) also work with for-of as well. Essentially for-of can iterate over any object that could be iterated over. That’s where the power & worth of for-of really come through. An object is iterable if it implements a default iterator.

© 2020
Azadeh Faramarzi

This site is created and maintined by Azadeh Faramarzi , A passionate developer, sport and code lover who loves to share and write when she has some time.