Master Form Validation in Javascript: Learn How to Improve Your Forms Now!

Master Form Validation in Javascript: Learn How to Improve Your Forms Now!

05 Dec 2024
Beginner
163 Views
26 min read
Learn with an interactive course and practical hands-on labs

Free Javascript Course Online

JavaScript Form Validation

JavaScript Form Validation might seem complicated at first, but it’s really just about making sure users enter the right information. Have you ever been frustrated by submitting a form only to realize something was wrong, like a missing field or a poorly formatted email? That’s where JavaScript form validation steps in to catch those mistakes before the form is submitted.

In this JavaScript tutorial, we’ll break down how JavaScript Form Validation works, why it’s essential for user experience, and how it can make your forms smarter and more reliable. By the end, you’ll be able to apply validation techniques that ensure your forms run smoothly and efficiently. Let’s jump in!

Steps for Form Validation in JavaScript

When you're dealing with forms, the last thing you want is bad or incomplete data. Imagine submitting a form only to find out something’s wrong. Frustrating, right? That’s where JavaScript comes to save the day! Here's a simple way to approach form validation:

Step 1: Access the form elements: First, grab the form and its parts, like text fields, checkboxes, and so on. Think of it like opening a box to see what you’ve got to work with.

Step 2: Check each field: Once you’ve got everything, go through each item to ensure it’s filled out correctly. Check if the email follows the right format or if the password is long enough. This is where the real validation happens!

Step 3: Provide feedback: If something’s off, don’t leave the user guessing. Show them exactly what needs fixing. It’s like having a friend point out mistakes before you turn in your homework!

Step 4: Prevent form submission: If there’s an error, don’t just let the form be submitted. It’s like saying, “Hold on, let’s fix this before we go any further.”

Step 5: Submit the form: Once everything’s good, go ahead and submit the form. Now you're all set!

By following these steps, you’ll help users avoid mistakes and ensure you get the right data. It’s a win-win!

Types of Form Validation

There are a few ways to validate forms in JavaScript. Each method has its own strengths. Let’s take a look at your options:

  • Client-Side Validation: This happens right in the user’s browser before the form is even sent to the server. It's fast and gives instant feedback. Who doesn’t love that? But remember, it can be bypassed, so don’t rely on it alone. You still need other layers for security.
  • Server-Side Validation: After the form is submitted, the server checks the data again. This is super important for security because you can’t fully trust the client’s data. The downside? It’s slower since it requires a round trip to the server.
  • Real-Time Validation: This checks the data as the user types. Imagine typing your email and knowing instantly if it’s valid or not, no waiting until you click submit. It’s like having a helpful assistant guiding you along!

Each validation method has its time and place. By combining client-side, server-side, and real-time validation, you get the best of both worlds: fast responses, security, and a smooth user experience!

Various Use Cases

Now, let’s look at some examples of where and how you’d apply validation in real life. Whether you’re working with a simple form or a more complex one, JavaScript can help ensure the data entered is exactly what you need.

1. Form Validation using jQuery

jQuery is a popular JavaScript library that makes it super easy to handle form validation. Instead of writing a lot of code to check each field manually, you can use jQuery’s built-in functions. It saves time and helps keep your code clean.


let numbers = [1, 2, 3];
let doubled = numbers.map(num => num * 2);
console.log(doubled);    

Output:

[2, 4, 6]

Explanation:

This example doubles each number in the array. It’s like having a list of prices, and you want to double them for some reason (maybe a sale). The `.map()` function makes this task super simple. You only need to write one line of code to transform the entire array!

Read More: Array Methods in JavaScript

2. Number Validation in JavaScript

Sometimes, you need to ensure the user has entered a number. Maybe it's a price, age, or some other numerical value. You can use JavaScript to check if the input is indeed a number, and if it’s not, you can display a helpful message. It’s like making sure the user hasn’t typed a letter when they should've typed a number.


// Example of number validation
function validateNumber() {
    var number = document.getElementById("numberInput").value;
    if (isNaN(number)) {
        alert("Please enter a valid number.");
        return false;
    }
    return true;
}   

Output:

Alert: "Please enter a valid number." when non-numeric input is provided

Explanation:

This code checks, if the value entered, is a number using `isNaN().` If the user types something that isn’t a number, an alert pops up and says, “Please enter a valid number.” It’s a simple but important way to make sure you get the right kind of data.

3. Password Validation Form Using JavaScript

We all know that passwords need to be secure. So, you might want to make sure the user’s password is at least 8 characters long. If it’s too short, you can let them know to try again. This prevents weak passwords from slipping through.


// Password validation example
function validatePassword() {
    var password = document.getElementById("password").value;
    if (password.length < 8) {
        alert("Password must be at least 8 characters long.");
        return false;
    }
    return true;
}    

Output:

Alert: "Password must be at least 8 characters long." when password is less than 8 characters

Explanation:

This function checks if the password entered is at least 8 characters long. If it’s too short, the user gets an alert saying, “Password must be at least 8 characters long.” This ensures the password is long enough to be secure.

4. How to Validate and Confirm Passwords using JavaScript?

Often, when users create accounts, they’re asked to type their password twice. You want to make sure that both password fields match. If they don’t, the user will be confused later when they try to log in. So, validating that the "confirm password" field matches the "password" field is essential.


// Confirm password validation
function validateConfirmPassword() {
    var password = document.getElementById("password").value;
    var confirmPassword = document.getElementById("confirmPassword").value;
    if (password !== confirmPassword) {
        alert("Passwords do not match.");
        return false;
    }
    return true;
}   

Output:

Alert: "Passwords do not match." if the passwords are different

Explanation:

This function compares the values of the "password" and "confirm password" fields. If they do not match, the user receives an alert stating, "Passwords do not match." It ensures that the user enters the same password in both fields, preventing a mistake.

5. JavaScript Program to Validate Passwords using Regular Expressions

If you wish to go a step further, you may utilize regular expressions (regex) to ensure that the password complies with additional requirements. For example, you may want the password to include at least one uppercase letter, one number, and one special character. Regex is ideal for pattern matching, and you can use it to create rules like this.


// Password validation using regular expression
function validatePasswordWithRegex() {
    var password = document.getElementById("password").value;
    var regex = /^(?=.*[A-Z])(?=.*\d)(?=.*[@$!%*?&])[A-Za-z\d@$!%*?&]{8,}$/;
    if (!regex.test(password)) {
        alert("Password must contain at least one uppercase letter, one digit, and one special character.");
        return false;
    }
    return true;
}   

Output:

Alert: "Password must contain at least one uppercase letter, one digit, and one special character." if the conditions aren't met

Explanation:

This regex checks that the password contains at least one uppercase letter, one number, and one special character. If any of these conditions are missing, the user gets an alert telling them what’s wrong. This is a great way to ensure the password is strong and secure!

Additional JavaScript Form Validation Examples

JavaScript Form Validation ensures that users enter correct and meaningful data into forms on your website. It acts like a friendly assistant, guiding users to fix mistakes before submitting. Let's explore some common validation examples!

JavaScript Form Validation Example

This example checks if a required field, such as "Name," is left empty. It’s like a reminder not to miss any important questions.


function validateForm() {
    const name = document.getElementById("name").value;
    if (name === "") {
        alert("Name must be filled out.");
        return false;
    }
    alert("Form submitted successfully!");
}    

Output:

Form submitted successfully!

Explanation:

This script validates the name field to ensure it’s not left blank. If empty, an alert is shown; otherwise, the form submits smoothly.

JavaScript Retype Password Validation

Sometimes, you need users to retype their passwords to confirm they match. This example checks for that.


function validatePassword() {
    const password = document.getElementById("password").value;
    const confirmPassword = document.getElementById("confirmPassword").value;
    if (password !== confirmPassword) {
        alert("Passwords do not match!");
        return false;
    }
    alert("Passwords match!");
}    

Output:

Passwords match!

Explanation:

This function compares the password and confirm password fields. If they don’t match, the user will be prompted to recheck them.

JavaScript Number Validation

What if you need to ensure users only enter numbers in a field? This example validates numeric input.


function validateNumber() {
    const age = document.getElementById("age").value;
    if (isNaN(age) || age === "") {
        alert("Please enter a valid number.");
        return false;
    }
    alert("Number is valid!");
}    

Output:

Number is valid!

Explanation:

The script checks if the input is a number. If it’s not, an alert is shown, asking for a valid number.

JavaScript Validation with Image

What if your form needs an image upload? This example validates that an image file is selected.


function validateImage() {
    const image = document.getElementById("image").value;
    if (image === "") {
        alert("Please upload an image.");
        return false;
    }
    alert("Image uploaded successfully!");
}   

Output:

Image uploaded successfully!

Explanation:

This function ensures that the user selects an image before proceeding. If no file is chosen, an alert prompts them to do so.

JavaScript Email Validation

JavaScript Email Validationensures the user has entered a proper email format. Here’s how you can do it.


function validateEmail() {
    const email = document.getElementById("email").value;
    const regex = /^[^\s@]+@[^\s@]+\.[^\s@]+$/;
    if (!regex.test(email)) {
        alert("Please enter a valid email address.");
        return false;
    }
    alert("Email is valid!");
}   

Output:

Email is valid!

Explanation:

The function checks if the email follows the standard format (e.g., user@example.com). If not, it prompts the user to correct it.

JavaScript Forms

Forms are an essential part of websites, allowing users to interact by entering data. JavaScript enhances these forms by providing validation, dynamic interaction, and styling, ensuring a seamless user experience. Let’s dive into how JavaScript can elevate your forms!

JavaScript Form Validation

Validating forms ensures that users enter the right data before submitting. It helps avoid errors and improves the reliability of the collected information.

JavaScript Example

Here’s an example of validating a "Name" field using JavaScript:


function validateForm() {
    const name = document.getElementById("name").value;
    if (name === "") {
        alert("Name cannot be empty!");
        return false;
    }
    alert("Form submitted successfully!");
}    

Output:

Form submitted successfully!

Explanation:

This script checks if the "Name" field is empty. If it is, it alerts the user to fill it out. Otherwise, the form proceeds. It’s simple and helps avoid empty submissions!

HTML Form Example

Below is an example of how you can structure a form in HTML:


    Name:
    
    Submit
   

Output:

When the "Submit" button is clicked, the form runs the validation function. If the "Name" field is empty, an alert appears. Otherwise, it shows a success message.

Explanation:

The HTML `onsubmit` attribute is linked to the Functions in JavaScript `validateForm`. This prevents the form from submitting if validation fails.

JavaScript Can Validate Numeric Input

Need to ensure that users enter only numbers? Here’s how JavaScript can handle it:


function validateNumber() {
    const age = document.getElementById("age").value;
    if (isNaN(age) || age === "") {
        alert("Please enter a valid number.");
        return false;
    }
    alert("Valid number entered!");
}   

Output:

Valid number entered!

Explanation:

This script checks if the entered value is numeric. If not, an alert prompts the user to correct it. It’s useful for fields like age or quantity where non-numeric input isn’t allowed.

Automatic HTML Form Validation

HTML5 provides built-in validation features that work without requiring JavaScript. It’s a quick and easy way to ensure users provide valid input.

HTML Form Example

Here’s an example of HTML5 validation:


    Email:
    
    Submit
  

Output:

If the user enters an invalid email, the browser will display an error message saying "Please include an '@' in the email address."

Explanation:

The `type="email"` attribute in the input ensures that only valid email addresses are accepted. The browser handles the validation without needing JavaScript.

Data Validation

Data validation ensures that the data entered by users matches specific rules. JavaScript and HTML can work together to enforce these rules seamlessly.

Example:

If a form requires numbers between 10 and 50, you can use JavaScript or HTML constraints to enforce the rule.

HTML Constraint Validation

Constraint validation is a part of HTML5 that allows you to define rules directly in your form’s markup. JavaScript can be used to customize this further.

Example:

Use attributes like `required`, `pattern`, or `min` to define input constraints.

Constraint Validation CSS Pseudo Selectors

CSS pseudo-selectors like `:valid` and `:invalid` allow you to style inputs based on their validity. You can give visual cues to users when their input meets or fails validation rules.

Example:

Style a field with a green border when valid or a red border when invalid:


input:valid {
    border: 2px solid green;
}
input:invalid {
    border: 2px solid red;
}

Explanation:

These CSS rules dynamically style the inputs based on the user's data, providing instant feedback without JavaScript.

Color Picker

A color picker input ensures that users can select only valid color values. Here’s an example:


    Choose a color:
    
    Submit
 

Output:

The browser provides a color picker interface, ensuring the input is always valid.

Explanation:

The `type="color"` input restricts users to selecting valid color codes, making it intuitive and error-free.

Summary

This article covers JavaScript Form Validation, teaching you how to ensure form inputs are accurate and complete before submission. It explains checking required fields, validating emails, matching passwords, and creating custom error messages. You’ll also learn to use preventDefault() to stop invalid submissions. With examples, this guide helps you improve user experience and maintain clean, structured data.

Want to learn more about JavaScript? Sign up for the ScholarHat JavaScript Programming Course today and become a JavaScript pro! Don't miss your chance to improve your skills and take your career to the next level!

FAQs

To add form validation in JavaScript, use the onsubmit event to trigger validation functions. Check each input field using conditions like if statements to ensure required values, correct formats (e.g., email), and matching passwords. Use preventDefault() to stop the form submission if the data is invalid.

There are two main types of form validation in JavaScript: Client-side validation and Server-side validation. Client-side validation checks input fields in the browser using JavaScript, ensuring quick feedback, while server-side validation verifies data on the server for added security.

The purpose of basic validation is to check if all required fields in a form are filled and meet basic criteria, such as ensuring no field is left empty or that input matches a simple pattern like numbers or text. It helps prevent incomplete or incorrect data submission.

Form validation in JavaScript is important to ensure accurate and complete data submission, improve user experience with instant feedback, and reduce server load by catching errors early. It also helps maintain data integrity and prevents invalid or malicious inputs.

Take our Javascript skill challenge to evaluate yourself!

In less than 5 minutes, with our skill challenge, you can identify your knowledge gaps and strengths in a given skill.

GET FREE CHALLENGE

Share Article
About Author
Shailendra Chauhan (Microsoft MVP, Founder & CEO at ScholarHat)

Shailendra Chauhan, Founder and CEO of ScholarHat by DotNetTricks, is a renowned expert in System Design, Software Architecture, Azure Cloud, .NET, Angular, React, Node.js, Microservices, DevOps, and Cross-Platform Mobile App Development. His skill set extends into emerging fields like Data Science, Python, Azure AI/ML, and Generative AI, making him a well-rounded expert who bridges traditional development frameworks with cutting-edge advancements. Recognized as a Microsoft Most Valuable Professional (MVP) for an impressive 9 consecutive years (2016–2024), he has consistently demonstrated excellence in delivering impactful solutions and inspiring learners.

Shailendra’s unique, hands-on training programs and bestselling books have empowered thousands of professionals to excel in their careers and crack tough interviews. A visionary leader, he continues to revolutionize technology education with his innovative approach.
Accept cookies & close this