It's a gloomy Monday, and you are at work. We all know how depressing Mondays can be, right? Your boss approaches you and says, "Hey, I have 300 unopened emails we've received over the weekend. I want you to open each one, write down the sender's name, and delete the emails once you're done."
This task looks very tiring if you try to do it manually. The next thing on your mind is probably to get on Google and look for software that can automate this process and make your life easier, right?
Well, we have similar situations in programming. There are times when you need to perform repeated tasks until they're done. How do you solve this issue? In JavaScript, we have what we refer to as loops. Loops allow us to solve repeated tasks by reducing the amount of code needed to complete the task.
In this article, we'll discuss what a loop is, how it works, and the various methods we can use to apply it in our programs.
Loops are used in JavaScript to perform repeated actions easily. They are based on a condition that returns true or false.
A condition is an expression that must be passed to keep a loop running. A loop runs when the specified conditions returns a true value and stops when they return a false value.
Loops are useful for carrying out repetitive tasks. For example, using a loop shortens the code needed to solve a problem. It saves time, optimizes memory usage, and improves flexibility.
A loop true significance extends beyond reducing code length and limiting repetition. They also help when working with data in an array, object, or other structures. Moreover, loops promote code modularity by reducing repetitive code and increasing code reusability, which makes it possible to create codes that can be used within different parts of your project.
There are two major categories of loops: entry-controlled loops and exit-controlled loops.
Entry-controlled loops evaluate the condition at the "entrance of the loop" before executing the loop's body. If the condition is true, the body runs. If not, the body doesn't run. The for and while loops are examples of entry-controlled loops.
Exit-controlled loops focus on the loop's body over the test condition, ensuring that the loop's body is executed at least once before evaluating the test condition. A good example of an Exit-controlled loop is the do-while loop.
Let's examine some examples of entry-controlled loops:
A while loop has the following syntax.
while (condition) { // loop's body }
The following list explains the functionality of a while loop:
Below, let's take a practical example on the while loop:
let arr = []; let i = 1; let number = 5; while (i <= number) { arr.push(i) i++ }
console.log(arr)
The push() method is a built-in JavaScript function that adds a new item to the end of an array.
Output
[1, 2, 3, 4, 5]
A do-whileloop closely resembles the while loop; the main difference between the while and the do-whileloop is that the do-while loop ensures code execution at least once before evaluating the loop's condition, the do-while loop has the following syntax below.
do { // loop's body } while (//condition)
The do-while is an excellent example of an exit-controlled loop. This lies in the fact that exit-controlled loops give priority to the loop's body before the test condition, now let's delve into a practical code example utilizing the do-while loop.
Example:
let i = 1; let num = 5; do { console.log(i); i++; } while (i <= num);
Now let's break down this code snippet:
Output
1 2 3 4 5
Although the do-while loop is very much similar to the while loop, there are subtle differences we must note, let’s take another example that compares the difference between the while and do-while loop.
let i = 5; let num = 4 while( i < num) { console.log(i) }
This while loop above won't return any result to the console, now why is this so?
now let's take a similar example with the do-while loop.
let i = 5; let num = 4; do { console.log(i) } while ( i < num)
Output
5
The do-while loop ensures the execution of the code block, which returns 5 into the console, although "i" has a higher value than "num" initially, it's still logged in the console once. This representation shows you the difference in functionality between the do-while and while loop.
The for loop is a unique type of loop and one of the most commonly used loop by programmers, the for loop is a loop that runs a code block for a specific number of time depending on a condition. The for loop has the following syntax below.
for (Expression1...; Expression2....; Expression3...{ //code block }
Expression1: This part of a for loop is also known as the initialization area, it's the beginning of our for loop and the area where the counter variable is defined; the counter variable is used to track the number of times the loop runs and store that as a value.
Expression2: This is the second part of the loop, this part defines the conditional statement that would execute the loop.
Expression3: This is where the loop ends; the counter variable in this section updates its value after each iteration either by increasing or decreasing the value as specified in the condition.
Let's dive into an example using the for loop.
for (let i = 0; i < 100; i++) { console.log("Hello World" ) }
From the code snippet above, let's break it down together.
Output
Hello World Hello World Hello World ... //repeated 97 more times making it 100 "Hello World" in total ...
The for-each loop is a method in JavaScript that travels through an array and applies a callback function on each element in that array; a callback function is simply another function passed as a parameter into a function, the callback function works by running sequentially after the main function is done executing.
Let's examine the basic syntax of a for-each loop.
array.forEach(function(currentValue, index, arr))
The provided code above explains the workings of a for-each loop.
let myArray = [1, 2, 3, 4, 5]; array.forEach((num, index, arr) => { arr[index] = num * 2; console.log(array); });
Let's break down the example above:
Take note, the for-each array method does not return a new array; rather, it modifies the original array and returns it.
Output
[2, 4, 6, 8, 10]
The for... in and for... of loops are very useful when it comes to iterating over iterable objects, iterable objects refers to any element that is capable of being looped over, common examples of iterables objects are arrays, strings, sets, etc.
The for... in and for... of are similar in how they iterate/move through objects, the main difference between them is shown on how they return values.
A for... in loop is useful when you need to extract the key(s)/properties from an object and it corresponding properties from the parent object, the for... in loop at times might iterate through an object in a manner that is different from the way it was defined in that particular object, let's take an example of a for... in loop in action.
let namesArray = []; const studentScores = { John: 60, Dan: 53, Tricia: 73, Jamal: 45, Jane: 52 } for(const name in studentScores){ namesArray.push(name); } console.log(namesArray);
In the example above, we have defined an object named studentScores that contains several student names and their corresponding scores, by using for... in, we were able to retrieve only the names of the students, which represent the keys of the object studentScores, and store them in an array by using the push() method.
Output
["John", "Dan", "Tricia", "Jamal", "Jane"]
The for... of loop is a special type of loop that iterates over the values of iterable objects such as arrays, strings, maps, e.t.c., for... of loops does not concern itself with the keys or properties of an object, rather it shows priorities on the values only, the for... of loop is unable to iterate over regular objects and will throw an error since they are not iterable. Let's take an example using the for.. of loop.
let numArray = [1,2,3,4,5] for (const value of numArray) { console.log(value) }
// Output = 1,2,3,4,5
In summary, the for... in and for... of loops are great way to loop through iterable objects, the main difference is a for... in loop returns the key of an Object while the for... of loop returns only the values of iterable objects.
An infinite loop refers to a loop that continues to run indefinitely; this occurs when a loop has no defined exit condition. Infinite loops are dangerous because they can crash your browser and lead to unwanted actions in your program.
// infinite loop sample
while (true) {
console.log("keep on running")
}
To prevent infinite loops in your program, always ensure that there is an exit condition defined within your loop.
Thank you very much for getting to the end of this article, loops in Javascript are important concept every developer needs to master as it is very valuable to creating a good and optimizable program, I believe with this article you would be able to understand the basics and intricacies of using loops in your program.
The above is the detailed content of JavaScript Loops for Beginners: Learn the Basics. For more information, please follow other related articles on the PHP Chinese website!