How to Check if String Ends with Number in Javascript
In this tutorial, you will learn how to check if string ends with number in javascript. A number is formed by the combination of digits from 0 to 9. From a developer perspective, it can be a bit tricky to find if a string ends with a number.
There are numerous ways to check if a string ends with a number. But for the sake of simplicity, we will use the length
property, charAt()
method, regular expression, and ternary operator (?
) to accomplish our goal. The length
property returns the length of the string. If the string is empty, then it will return 0.
The test(
) method of RegExp object is used to perform a pattern search in a string and returns a Boolean value. A string consists of multiple characters and these characters in a string have a 0-based index. That means the first character in a string has an index of 0 and to get that character by index, we can use charAt()
method.
In the following example, we have one global variable that holds a string. Upon click of a button, we will check if the string ends with a number 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
myString
which holds a string as its value. - We have the
regExp
variable which holds a regular expression/\d/
as its value to match numbers. - In the event handler function, we are getting the last character from string using
charAt()
method. By subtracting 1 from thelength
property, we are passing index of the last character to thecharAt()
method. The last character is stored in thelastChar
variable. - We are calling the
test()
method of regExp and passinglastChar
as a parameter. It will return a Boolean value which we are storing in thefound
variable. - We are using the ternary operator (
?
) and checking whetherfound
is true or false. If it is true, that means the string ends with a number. - 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 myString = "The number is 587"; let regExp = /\d/; btnCheck.addEventListener("click", () => { let lastChar = myString.length - 1; let found = regExp.test(lastChar) let result = found ? "Yes" : "No"; output.innerText = result; });