Blog
JavaScript

JavaScript String Search and Pattern Matching

Finding and Extracting Text with Precision

JavaScript String indexOf()

The indexOf() method returns the index (position) of the first occurrence of a string in a string, or it returns -1 if the string is not found:
javascript
JavaScript counts positions from zero. 0 is the first position in a string, 1 is the second, 2 is the third, ...

JavaScript String lastIndexOf()

The lastIndexOf() method returns the index of the last occurrence of a specified text in a string:

javascript

Both indexOf(), and lastIndexOf() return -1 if the text is not found:

javascript

Both methods accept a second parameter as the starting position for the search:

javascript

The lastIndexOf() methods searches backwards (from the end to the beginning), meaning: if the second parameter is 15, the search starts at position 15, and searches to the beginning of the string.

javascript

JavaScript String search()

The search() method searches a string for a string (or a regular expression) and returns the position of the match:

javascript
javascript

Did You Notice?

The two methods, indexOf() and search(), are equal? They accept the same arguments (parameters), and return the same value? The two methods are NOT equal. These are the differences:

  • The search() method cannot take a second start position argument.
  • The indexOf() method cannot take powerful search values (regular expressions).

You will learn more about regular expressions in a later chapter.

JavaScript String match()

The match() method returns an array containing the results of matching a string against a string (or a regular expression).

Perform a search for "ain":

javascript

Perform a search for "ain":

javascript

Perform a global search for "ain":

javascript

Perform a global, case-insensitive search for "ain":

javascript

If a regular expression does not include the g modifier (global search), match() will return only the first match in the string. Read more about regular expressions in the chapter JS RegExp.

JavaScript String matchAll()

The matchAll() method returns an iterator containing the results of matching a string against a string (or a regular expression).

javascript

If the parameter is a regular expression, the global flag (g) must be set, otherwise a TypeError is thrown.

javascript

If you want to search case insensitive, the insensitive flag (i) must be set:

javascript
matchAll() is an ES2020 feature.
matchAll() does not work in Internet Explorer.

JavaScript String includes()

The includes() method returns true if a string contains a specified value. Otherwise it returns false.

Check if a string includes "world":

javascript

Check if a string includes "world". Start at position 12:

javascript
includes() is case sensitive. includes() is an ES6 feature. includes() is not supported in Internet Explorer.

JavaScript String startsWith()

The startsWith() method returns true if a string begins with a specified value. Otherwise it returns false:

  • Returns true:
javascript
  • Returns false:
javascript

A start position for the search can be specified:

  • Returns false:
javascript
  • Returns true:
javascript
startsWith() is case sensitive.
startsWith() is an ES6 feature.
startsWith() is not supported in Internet Explorer.

JavaScript String endsWith()

The endsWith() method returns true if a string ends with a specified value. Otherwise it returns false:

Check if a string ends with "Doe":

javascript

Check if the 11 first characters of a string ends with "world":

javascript
endsWith() is case sensitive.
endsWith() is an ES6 feature.
endsWith() is not supported in Internet Explorer.

Complete String Reference

For a complete String reference, go to our: Complete JavaScript String Reference. The reference contains descriptions and examples of all string properties and methods.

avatar

0 Comments

No comments

Leave a Reply

avatar

Recent Post

Related Topics

    Feeds

      Don't miss what's next 👋

      Enjoyed this content? Leave your email to get notified when we publish new insights, tutorials, and updates — no spam, ever.