Learn how to create a login form in React JS with robust validation techniques. Build secure authentication systems for your web applications effortlessly.
Table of Contents
Welcome to our comprehensive guide on building a secure login form in React JS with validation. In today's digital landscape, user authentication is paramount for safeguarding sensitive information and ensuring a seamless user experience. React JS, with its robust ecosystem and state-of-the-art features, provides an ideal platform for creating dynamic and interactive web applications.
Throughout this tutorial, we'll walk you through each step of the process, from setting up your React project environment to implementing form validation and handling form submission. Whether you're a beginner or an experienced developer, this guide will equip you with the knowledge and tools necessary to create a reliable and user-friendly login system.
So, let's dive in and explore the world of React JS login form development together!
Setting Up React Project Environment
To get started, make sure you have Node.js and npm installed on your system. Create a new React project using the Create React App or any preferred method.
How to Set Up React Project Environment:
- Install Node.js and npm.
- Create a new React project using Create React App: npx create-react-app login-form.
- Navigate to the project directory: cd login-form.
Source Code
Step 1 (HTML Code):
When you build a React application, you typically have a JavaScript file where you define your main application logic. This file is called index.js
Inside this main JavaScript file (index.js), you import various React components that make up your application's UI and functionality.
ReactDOM Rendering: React provides a library called ReactDOM which is responsible for rendering React components into the HTML DOM. In the index.js file, you'll typically find a line of code that uses ReactDOM to render your top-level component into the HTML DOM. This is where the <div id="root"></div> comes into play.
The <div id="root"></div> acts as a mounting point or a target DOM element where your React application will be injected. When ReactDOM.render() is called, it takes your top-level React component (usually a component representing the entire application) and injects it into this <div id="root"></div>, effectively rendering your entire application within this single HTML element.
Step 2 (CSS Code):
Define your styles in a separate CSS file and import them into your component. For example import './LoginForm.css';
Let's break down each part:
1. *, *::before, *::after: This targets all elements, pseudo-elements before, and pseudo-elements after, setting their box-sizing to border-box. This ensures that padding and border are included in the element's total width and height.
2. body: Styles for the body of the document. It sets the font family to Montserrat or sans-serif if Montserrat is not available. It makes the body occupy the full viewport height (100vh). It uses CSS Grid to center its content both horizontally and vertically. It sets the text color to a shade of gray (#4f546c) and the background color to a shade of blue (#5930ff).
3. .container: This class styles a container element within the body. It gives it a white background, some padding, and a slight border-radius for rounded corners. The width is set to 20rem.
4. .container__header: Styles for the header within the container. It adds a margin at the bottom to separate it from other elements.
5. .form: Styles for a form element. It uses a flexbox to stack its child elements vertically, with a gap of 2rem between them.
6. .form__group: Styles for a group of form elements. It positions the elements relatively and stacks them vertically.
7. .form__label: Styles for labels within form elements. They are positioned absolutely to sit on top of their respective inputs. They have a white background, some padding, and a smaller font size.
8. .form__input: Styles for input fields. They have padding, inherit font family and color, no outline, a border, and a border-radius.
9. .form__successicon, .form__erroricon: Styles for success and error icons within form elements. They are positioned absolutely at the top right corner, with a small width. By default, they are set to display:none.
10. .form__success, .form__error: Styles applied when the form input is in a success or error state, respectively. They change the border color of the input and display the corresponding icon.
11. .form__message: Styles for error messages are displayed below the form inputs. They have a smaller font size, a slight margin at the top, and a red color. By default, they are set to display:none.
12. .form__button: Styles for form buttons. They have no outline or border, some padding, a border radius, inherit font family, a cursor pointer, a blue background color, and a white text color.
Step 3 (JavaScript Code):
Let's create a new component for our login form. We'll use JSX to define the structure of the form and React hooks for managing its state.
How to Create the Login Form Component:- Create a new file named LoginForm.js.
- Define the structure of the form using JSX.
- Implement the useState hook to manage form fields' state.
Let's break down the code step by step:
1. Imports:
- useState, useEffect, useRef, StrictMode, and ChangeEvent are destructured from the React library.
- createRoot is destructured from the ReactDOM library.
2. Root Element and Root Creation:
- It selects the DOM element with the id 'root'.
- It creates a root using createRoot from ReactDOM.
3. App Component:
- It defines the main functional component App.
- Initializes state using useState with an initial state object containing email and password fields.
- Utilizes useRef to create references for email input, password input, and the submit button.
- Defines functions for handling change, blur, keyup events, and form submission.
- Checks and validates email and password inputs.
- Renders a form with email input, password input, and a submit button.
- It utilizes conditional rendering to display success or error icons and messages based on input validation.
4. Input Validation Functions:
- isEmail: Validates email using a regular expression.
- isPass and isPass2: Validates password based on certain criteria such as lowercase, uppercase, numeric, special characters, and length.
- setErrorFor and setSuccessFor: Functions to set error and success styles/messages for inputs.
5. Event Handlers:
- handleChange: Updates the form state on input change.
- handleBlur: Handles blur events to validate inputs.
- handleKeyUp: Handles keyup events to validate inputs.
- handleSumit: Handles form submission, checks inputs, and displays loading spinner on successful submission.
6. Rendering:
- Renders the App component within a StrictMode component using root.render.
Final Output:
Conclusion:
In conclusion, building a login form in React JS with validation is a crucial aspect of front-end development, especially in web applications requiring user authentication. By following the steps outlined in this tutorial, you've learned how to create a robust and secure login system using React's powerful features.
From setting up your project environment to implementing form validation and handling form submissions, you've gained valuable insights into best practices and techniques for building user-friendly interfaces.
With your newfound knowledge and skills, you're well-equipped to tackle complex authentication challenges and contribute to the creation of seamless web experiences.
Thank you for joining us on this journey, and happy coding!
That’s a wrap!
I hope you enjoyed this post. Now, with these examples, you can create your own amazing page.
Did you like it? Let me know in the comments below 🔥 and you can support me by buying me a coffee
And don’t forget to sign up to our email newsletter so you can get useful content like this sent right to your inbox!
Thanks!
Faraz 😊