Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/codewithalamin/intro-signup-form
Responsive sign-up form with form validation using JavaScript.
https://github.com/codewithalamin/intro-signup-form
codepapa360 codewithalamin css forms frontend html javascript responsive-design validation web-development
Last synced: 14 days ago
JSON representation
Responsive sign-up form with form validation using JavaScript.
- Host: GitHub
- URL: https://github.com/codewithalamin/intro-signup-form
- Owner: CodeWithAlamin
- License: mit
- Created: 2023-04-13T10:45:22.000Z (almost 2 years ago)
- Default Branch: main
- Last Pushed: 2024-10-30T12:10:16.000Z (3 months ago)
- Last Synced: 2024-11-11T03:18:07.380Z (2 months ago)
- Topics: codepapa360, codewithalamin, css, forms, frontend, html, javascript, responsive-design, validation, web-development
- Language: SCSS
- Homepage: https://intro-signup-form-alamin.netlify.app
- Size: 541 KB
- Stars: 1
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE.md
Awesome Lists containing this project
README
Intro component with signup form
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.## Screenshot
## The challenge
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: `[email protected]`). The message for this error should say _"Looks like this is not an email"_## Built with
- Semantic HTML5 markup
- CSS custom properties
- JavaScript
- Mobile-first workflow
- NPM
- Webpack## Installation
- Clone this repo:
```sh
git clone https://github.com/CodeWithAlamin/Intro-signup-form.git
```- Install dependencies:
```sh
npm install
```- Build command:
```sh
npm run build
```- Run command:
```sh
npm start
```## What I learned
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.
## Useful resources
- [RegexMagic](https://www.regular-expressions.info/email.html) - 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.
## Author
👤 Alamin
- Twitter - [@CodeWithAlamin](https://www.twitter.com/CodeWithAlamin)
- LinkedIn - [@CodeWithAlamin](https://www.linkedin.com/in/CodeWithAlamin)
- Frontend Mentor - [@CodeWithAlamin](https://www.frontendmentor.io/profile/CodeWithAlamin)
- Github: [@CodeWithAlamin](https://github.com/CodeWithAlamin)Feel free to contact me with any questions or feedback!
## Show your support
Give a ⭐️ if you liked this project!
## Acknowledgments
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.
## License
This project is licensed under the [MIT](https://github.com/CodeWithAlamin/Intro-signup-form/blob/main/LICENSE.md) 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!