How to Check Whether a String is Palindrome or Not in Javascript
In this tutorial, you will learn how to check whether a string is palindrome or not in javascript. A palindrome is a word, sentence, or number which reads the same backward as well as forward such as level, madam, refer, 1221, etc.
There are numerous ways to check whether a string is palindrome or not. We are going to use one of the easiest solutions which involve the usage of the Array.from()
method, reverse()
method, join()
method, and ternary (?
) operator.
The Array.from()
method returns an array from any object that has a length property. The reverse()
method reverses the order of items in an array. The join()
method converts an array into a string. It also takes a separator as a parameter, but it is optional. The default separator is a comma (,
). The ternary operator is also known as the conditional operator which acts similar to the if-else statement.
In the following example, we have one global variable and upon click of a button, we will check whether the string is palindrome or not and display the result on the screen. Please have a look over the code example and the steps given below.
HTML & CSS
- We have 3 elements in the HTML file (
div
,button
, andh1
). Thediv
element is just a wrapper for the rest of the elements. - The
innerText
for thebutton
element is“Check”
and for theh1
element, it is“Result”
. - We have done some basic styling using CSS and added the link to our
style.css
stylesheet inside thehead
element. - We have also included our javascript file
script.js
with ascript
tag at the bottom.
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <meta http-equiv="X-UA-Compatible" content="ie=edge"> <link rel="stylesheet" href="style.css"> <title>Document</title> </head> <body> <div class="container"> <button>Check</button> <h1>Result</h1> </div> <script src="script.js"></script> </body> </html>
.container { text-align: center; } button { margin-top: 10px; padding: 10px 20px; }
Javascript
- We have selected the
button
element andh1
element using thedocument.querySelector()
method and stored them inbtnCheck
andoutput
variables respectively. - We have attached a
click
event listener to thebutton
element. - We have a global variable
myVar
which holds a palindrome string as its value. - In the event handler function, we are calling the
isPalindrome()
method and passingmyVar
as a parameter. This method will check whether a string is palindrome or not and return a Boolean value. - In the
isPalindrome()
method, we are converting the string to an array of characters using theArray.from()
method, reversing the array using thereverse()
method, and converting it back to a string using thejoin()
method. The returned string is stored in thereverseStr
variable. - We are using the strict equality operator (
===
) to check whether the original string and reversed string are equal. This check will give us a Boolean value and we will simply return it. - Depending upon the result of the check, we will assign
“Yes”
or“No”
to theresult
variable. - We are displaying the
result
in theh1
element using theinnerText
property.
let btnCheck = document.querySelector("button"); let output = document.querySelector("h1"); let myVar = "radar"; btnCheck.addEventListener("click", () => { let result = isPalindrome(myVar) ? "Yes" : "No"; output.innerText = result; }); function isPalindrome(str) { let reverseStr = Array.from(str).reverse().join(""); return str === reverseStr; }