DEV Community

Megan Paffrath
Megan Paffrath

Posted on

Loops: For Loops, While Loops, For...Of Loops, For...In Loops

The point of looping is to repeat some functionality.

Some types of loops include:

  • for loop
  • while loop
  • for...of loop
  • for...in loop

For Loop

To can write a simple for loop as follows:

for (let i = 1; i <= 10; i++) {
  console.log(i); // prints numbers 1-10
}
Enter fullscreen mode Exit fullscreen mode

To loop over an array, we can do as follows:

const animals = ['lizard', 'fish', 'turtle'];

for (let i = 0; i < animals.length; i++) {
  console.log(i, animals[i]);
}
// 0 'lizard'
// 1 'fish'
// 2 'turtle'
Enter fullscreen mode Exit fullscreen mode

We can also loop over this array in reverse:

for (let i = animals.length - 1; i >= 0; i--) {
  console.log(i, animals[i]);
}

// 2 'turtle'
// 1 'fish'
// 0 'lizard'
Enter fullscreen mode Exit fullscreen mode

We can also make a loop within a loop:

for (let i = 0; i <= 2; i++) {
  for (let j = 0; j < 2; j++) {
    console.log(`i=${i}, j=${j}`);
  }
}

// i=0, j=0
// i=0, j=1
// i=1, j=0
// i=1, j=1
// i=2, j=0
// i=2, j=1
Enter fullscreen mode Exit fullscreen mode

This is useful if we want to iterate over an array of arrays:

const seatingChart = [
  ['Abigale', 'Tim', 'Cynthia'],
  ['Bob', 'Carter', 'Zane', 'Tanja'],
  ['Quin', 'Xavier'],
];

// To print each name individually from seatingChart:
for (let i = 0; i < seatingChart.length; i++) {
  for (let j = 0; j < seatingChart[i].length; j++) {
    console.log(seatingChart[i][j]);
  }
}
Enter fullscreen mode Exit fullscreen mode

While Loop

An example of a simple while loop is:

let num = 0;

// to print out 0 through 4:
while (num < 5) {
  console.log(num);
  num++;
}
Enter fullscreen mode Exit fullscreen mode

Break keyword

The break keyword can be used to exit a while loop:

let input = prompt('Say something:');
while (true) {
  input = prompt(input);
  if (input === 'stop copying me') {
    break; // finally stops prompting user
  }
}
Enter fullscreen mode Exit fullscreen mode

It can also be used to exit a for loop. Let's say we have the line:

let line = ['Abby', 'Salvia', 'Jamie', 'Carter', 'John'];
Enter fullscreen mode Exit fullscreen mode

and we want to output everyone that comes before Jamie, but not Jamie:

for (let i = 0; i < line.length; i++) {
  if (line[i] === 'Jamie') break;
  console.log(line[i]);
}
Enter fullscreen mode Exit fullscreen mode

For...Of Loops

If we want to print each value from an array, we can do something like:

let people = ['Agitha', 'Bruce', 'Charlie', 'Dane', 'Ernie'];
// to print each persons name:
for (let person of people) {
  console.log(person);
}
Enter fullscreen mode Exit fullscreen mode

To make our seating chart example from before more legible, we can do:

const seatingChart = [
  ['Abigale', 'Tim', 'Cynthia'],
  ['Bob', 'Carter', 'Zane', 'Tanja'],
  ['Quin', 'Xavier'],
];

// To print each name individually from seatingChart:
for (let row of seatingChart) {
  for (let person of row) {
    console.log(person);
  }
}
Enter fullscreen mode Exit fullscreen mode

For...In Loops

If we want to iterate through each key value pair in an object, we can do something like:

const testScores = {
  jim: 34,
  abby: 93,
  greg: 84,
  mark: 95,
  melvin: 73,
};

for (let person in testScores) {
  console.log(`${person} scored ${testScores[person]}`);
}
Enter fullscreen mode Exit fullscreen mode

If we want to get the average of the testScores using For...Of, we can do as follows:

let total = 0;
let scores = Object.values(testScores);
for (let score of scores) {
  total += score;
}
let avg = total / scores.length;
console.log(avg);
Enter fullscreen mode Exit fullscreen mode

SurveyJS custom survey software

JavaScript UI Libraries for Surveys and Forms

SurveyJS lets you build a JSON-based form management system that integrates with any backend, giving you full control over your data and no user limits. Includes support for custom question types, skip logic, integrated CCS editor, PDF export, real-time analytics & more.

Learn more

Top comments (0)

Sentry image

See why 4M developers consider Sentry, “not bad.”

Fixing code doesn’t have to be the worst part of your day. Learn how Sentry can help.

Learn more