JavaScript Strings

What are JavaScript Strings?

JavaScript strings are a fundamental data type used to represent and manipulate text. They are a sequence of characters enclosed within single quotes (''), double quotes (""), or backticks (`). Strings store and display text and can be used in various ways, such as combining multiple strings (concatenation), finding the length, accessing specific characters, or changing the case of the text.

JavaScript provides many built-in methods and properties for working with strings. These include functions for searching, replacing characters, splitting strings into arrays, and extracting portions of strings. Properties like length give useful information about the string's size.

String Basics

Definition of a String

A string in JavaScript represents a sequence of characters. Strings are immutable, meaning once created, they cannot be changed. Strings are defined using single quotes, double quotes, or backticks. They can be manipulated through concatenation (+ operator), case conversion, or substring extraction.

JavaScript provides several methods like indexOf(), slice(), replace(), and trim() for handling and processing strings.

Single Quotes vs. Double Quotes

In JavaScript, both single and double quotes can be used for defining strings. The main difference is their typical usage: single quotes are commonly used for string literals, while double quotes are often used with HTML attributes.

Backticks (`), used for template literals, offer additional features like multiline strings and variable interpolation. Consistency in quote style is important for maintaining readable and organized code.

Creating String Objects

To create a string object, you can use the String() constructor:

var myString = new String("Hello, World!");

However, it's recommended to avoid string objects in favor of primitive string values, as objects use more memory and can slow down the program:

var myString = "Hello, World!";

String Literals and Values

String Literals vs. Strings as Variables

String literals are fixed values enclosed in quotes and used directly in code. Strings as variables, created using the new keyword, allow for dynamic manipulation:

let greeting = new String("Hello, World!");

While literals are efficient for static text, string variables are useful for more complex, dynamic operations.

Original Strings and Template Literals

Template literals, denoted by backticks, allow for breaking long strings across multiple lines and embedding expressions. For example:

let name = 'John';
console.log(`Hello, my name is ${name}`);

Template literals simplify string handling by avoiding the need for concatenation.

Primitive Data Type: Strings

In JavaScript, strings are a primitive data type, created using quotes ('hello' or "world"). Unlike string objects, primitives are immutable. JavaScript automatically wraps string primitives into objects when methods are called.

To convert a string object to its primitive form, you can use the valueOf() or toString() methods.

Special Characters in Strings

Escape Sequences for Special Characters

Escape sequences in JavaScript allow the inclusion of special characters like newlines (\n), backslashes (\\), or quotes (\', \"). These sequences help insert non-printable characters or symbols into strings.

Common Special Characters

Special characters such as the ampersand (&), dollar sign ($), and exclamation point (!) are often used in programming. Escape sequences ensure proper handling of these symbols within strings.

Template Literals and Interpolation

Overview of Template Literals

Template literals, enclosed in backticks, allow the embedding of variables and expressions directly into strings using ${} placeholders. This makes string creation more dynamic and readable:

let name = "John";
let greeting = `Hello, ${name}!`;

Variable Interpolation in Template Literals

Variable interpolation is a key feature of template literals. It allows for dynamic content within strings without needing complex concatenation:

let age = 25;
let message = `I am ${age} years old.`;

Template literals provide a cleaner, more efficient way to work with strings in JavaScript.

Written by

Master JavaScript by choosing your ideal learning course

View all courses

Create a free account to access the full topic

Sign up with Google
Sign up with Google
Sign up with JetBrains
Sign up with JetBrains
Sign up with Github
Sign up with GitHub
Coding thrill starts at Hyperskill
I've been using Hyperskill for five days now, and I absolutely love it compared to other platforms. The hands-on approach, where you learn by doing and solving problems, really accelerates the learning process.
Aryan Patil
Reviewed us on