Syntax
for ([initialization]; [condition]; [final-expression])
statement
The javascript for
statement consists of three expressions and a statement:
- initialization - Run before the first execution on the loop. This expression is commonly used to create counters. Variables created here are scoped to the loop. Once the loop has finished it's execution they are destroyed.
- condition - Expression that is checked prior to the execution of every iteration. If omitted this expression evaluates to true;
- final-expression - Expression that is run after every iteration. Usually used to increment a counter.
- statement - Code to be repeated in the loop
any of these three expressions or the statement can be omitted. For loops are commonly used to count a certain number of iterations to repeat a statement.
Common Pitfalls
Exceeding the bounds of an array
When indexing over an array many times it is easy to exceed the bounds of the array (ex. try to reference the 4th element of a 3 element array).
// This will cause an error.
// The bounds of the array will be exceeded.
var arr = [1,2,3];
for (var i = 0; i <= arr.length; i++) {
console.log(i);
}
output:
1
2
3
undefined
There are to ways to fix this code. Set the condition to either i < arr.length
or i <= arr.length - 1
Examples
for (var i = 0; i < 9; i++) {
console.log(i);
// more statements
}
output:
0
1
2
3
4
5
6
7
8
links: MDN
related: js-loops