8.2. Working With Arrays

8.2.1. Bracket Notation and Index

As previously discussed, arrays are an ordered collection where each item can be accessed via index. Similar to strings, an index in an array is the number order given to items. Individual items can be accessed using bracket notation (array[index]). Indexes are zero-based, going from 0 to array.length-1.

Example

Use bracket notation and index to access items in an array.

 1let programmingLanguages = [
 2   "JavaScript", // index 0
 3   "Python",     // index 1
 4   "Java",       // index 2
 5   "C#"          // index 3
 6];
 7console.log(programmingLanguages[0]);
 8console.log(programmingLanguages[3]);
 9
10// What will happen when index 4 is requested?
11console.log(programmingLanguages[4]);

Console Output

JavaScript
C#
undefined

Notice above that undefined was printed out when index 4 was referenced. undefined is returned when you request an index that the array does not contain.

Note

undefined is a special value in JavaScript that means no value has been assigned. We will discuss undefined more later in the class.

Example

undefined will be returned for any index that is outside of the array's index range.

1let programmingLanguages = ["JavaScript", "Python", "Java", "C#"];
2console.log(programmingLanguages[-1]);
3console.log(programmingLanguages[100]);

Console Output

undefined
undefined

8.2.2. Arrays are Mutable

In programming, mutability refers to what happens when you attempt to change a value. Remember that strings are immutable, meaning that any change to a string results in a new string being created. In contrast, arrays are mutable, meaning that individual items in an array can be edited without a new array being created.

Example

Update an item in an array using bracket notation and index.

1let javaScriptFrameworks = ["React", "Angular", "Ember"];
2console.log(javaScriptFrameworks);
3
4// Set the value of index 2 to be "Vue"
5javaScriptFrameworks[2] = "Vue";
6
7// Notice the value at index 2 is now "Vue"
8console.log(javaScriptFrameworks);

Console Output

[ 'React', 'Angular', 'Ember' ]
[ 'React', 'Angular', 'Vue' ]