Understanding strings as sequential collections of characters gives us much more than just a mental model of how they are structured. JavaScript provides a rich collection of tools---including special syntax and operations---that allows us to work with strings.
Bracket notation is the special syntax that allows us to access the individual characters that make up a string. To access a character, we use the syntax someString[i]
, where i
is the index of the character we want to access. String indices are integers representing the position of a character within a given string, and they start at 0. Thus, the first character of a string has index 0, the second has index 1, and so on.
Consider the string "JavaScript"
. The "J"
has index 0, the first "a"
has index 1, "v"
has index 2, and so on.
An expression of the form someString[i]
gives the character at index i
.
Example
This program prints out the initials of the person's name.
1let jsCreator = "Brendan Eich";
2let firstInitial = jsCreator[0];
3let lastInitial = jsCreator[8];
4
5let outputStr = "JavaScript was created by somebody with initials " +
6 firstInitial + "." +
7 lastInitial + ".";
8
9console.log(outputStr);
Console Output
JavaScript was created by somebody with initials B.E.
What happens if we try to access an index that doesn't exist, for example -1 or an index larger than the length of the string?
Try It!
1let jsCreator = "Brendan Eich";
2
3console.log(jsCreator[-1]);
4console.log(jsCreator[42]);
Question
What does an expression using bracket notation evaluate to when the index is invalid (the index does not correspond to a character in the string)?
Question
If phrase = 'Code for fun'
, then phrase[2]
evaluates to:
"o"
"d"
"for"
"fun"
Question
Which of the following returns true
given myStr = 'Index'
? Choose all correct answers.
myStr[2] === 'n';
myStr[4] === 'x';
myStr[6] === ' ';
myStr[0] === 'I';
Question
What is printed by the following code?
1let phrase = "JavaScript rocks!";
2console.log(phrase[phrase.length - 8]);
"p"
"i"
"r"
"t"