What are String and Template Literals in JavaScript?

Table of Contents

JavaScirpt and Template Literals

In JavaScript, a string is a data type that represents a sequence of characters. It can contain letters, numbers, symbols, and whitespace. Strings are commonly used to store and manipulate text-based data.

Template literals, also known as template strings, are a feature introduced in ECMAScript 2015 (ES6) to make working with strings in JavaScript more convenient. They allow for the embedding of expressions and variables inside a string, using a special syntax.

The syntax for creating a template literal is by using backticks (`) instead of single or double quotes. Here’s an example:

const name = “John”;
const age = 25;

const message = My name is ${name} and I'm ${age} years old.;

In this example, the template literal is enclosed between backticks. Inside the template literal, you can include placeholders ${expression} which will be replaced with the evaluated value of the expression. In this case, the variables name and age are interpolated into the message string.

Template literals offer several advantages over traditional string concatenation:

  1. Variable interpolation: Instead of using concatenation with the + operator, you can directly embed variables or expressions within the template string by enclosing them in ${}. This makes the code more readable and avoids the need for explicit string conversions.
  2. Multiline strings: Template literals preserve line breaks, allowing you to create multiline strings without the need for escape characters or concatenation.
  3. Expression evaluation: You can include any valid JavaScript expression inside the ${} placeholders, and it will be evaluated and converted to a string. This allows for more dynamic and complex string generation.

Template literals provide a flexible and concise way to work with strings in JavaScript, making code more readable and maintainable. They are widely used in modern JavaScript applications.

Here are a few examples of strings and template literals in JavaScript:

  1. Basic String:
const greeting = "Hello, world!";


Hello, world!
  1. Concatenation using Template Literal:
const firstName = "John";
const lastName = "Doe";
const fullName = `${firstName} ${lastName}`;


John Doe
  1. Multiline String using Template Literal:
const poem = `Roses are red,
Violets are blue,
Sugar is sweet,
And so are you.`;


Roses are red,
Violets are blue,
Sugar is sweet,
And so are you.
  1. Expression Evaluation in Template Literal:
const num1 = 5;
const num2 = 7;
const result = `${num1} + ${num2} = ${num1 + num2}`;


5 + 7 = 12
  1. Template Literal with Function:
function greet(name) {
  return `Hello, ${name}!`;

const userName = "Alice";
const greeting = greet(userName);


Hello, Alice!

These examples demonstrate the usage of both simple strings and template literals, showcasing their ability to include variables, expressions, and even function calls within the string itself.