This project is a signup form built with HTML, CSS, and JavaScript. It features form validation using regular expressions and DOM manipulation to show error messages and style form elements.
Users should be able to:
- View the optimal layout for the site depending on their device's screen size
- See hover states for all interactive elements on the page
- Receive an error message when the
form
is submitted if:- Any
input
field is empty. The message for this error should say "[Field Name] cannot be empty" - The email address is not formatted correctly (i.e. a correct email address should have this structure:
name@host.tld
). The message for this error should say "Looks like this is not an email"
- Any
- Semantic HTML5 markup
- CSS custom properties
- JavaScript
- Mobile-first workflow
- NPM
- Webpack
- Clone this repo:
git clone https://github.com/CodeWithAlamin/Intro-signup-form.git
- Install dependencies:
npm install
- Build command:
npm run build
- Run command:
npm start
In this project, I learned several key concepts related to form validation and manipulation using JavaScript. First, I learned how to use regular expressions to validate form inputs, such as email addresses, using the test()
method.
Next, I learned how to manipulate the DOM to show error messages and style form elements using JavaScript. This involved accessing the parent and sibling elements of each form input to display relevant error messages, and changing the border color and label color of each input to indicate its validity.
I also learned about the difference between the click event on a submit button and the submit event on a form. While both events can be used to trigger form submissions, the submit event allows for additional validation and prevents the form from being submitted if any input is invalid.
Furthermore, I learned how to check if all form inputs are valid before submitting the form using JavaScript. This involved looping through each input and checking its validity using a function that combined regular expression validation and DOM manipulation.
Finally, I learned how to handle form submissions using JavaScript, including accessing form inputs and submitting forms. This involved preventing the default form submission behavior using preventDefault()
and manually submitting the form using submit()
. Overall, this project provided a great introduction to working with form elements in JavaScript.
- RegexMagic - This article by Jan Goyvaerts provides an in-depth explanation of how to use regular expressions to validate email addresses. The article not only explains how to write regular expressions for email validation but also covers the common mistakes made while writing regular expressions for email validation.
It provides clear and concise examples of regular expressions for email validation and also explains the logic behind each regular expression.
👤 Alamin
- Twitter - @CodeWithAlamin
- LinkedIn - @CodeWithAlamin
- Frontend Mentor - @CodeWithAlamin
- Github: @CodeWithAlamin
Feel free to contact me with any questions or feedback!
Give a ⭐️ if you liked this project!
I would like to express my gratitude to Frontend Mentor for providing this project idea and design. Their platform is an excellent resource for web developers looking to improve their skills.
This project is licensed under the MIT license, which means you can use, modify, and distribute the code as you wish. If you have any questions or feedback, feel free to reach out. Thank you for considering my code!