HTML Forms for Beginners: Input Types, GET vs POST, and Accessibility

Table of contents
- What is an HTML Form?
- HTML Input Types Explained :
- GET vs POST: Which Method Should You Use?
- HTML Input Types Explained: From Text to Passwords.
- Making Forms Accessible with HTML Attributes :
- Basic Input Types
- 1. Text Input (type="text")
- 2. Password Input (type="password")
- 3. Email Input (type="email")
- 4. Number Input (type="number")
- Selection Input Types
- 5. Radio Button (type="radio")
- 6. Checkbox (type="checkbox")
- 7. Dropdown (<select>)
- Special Input Types
- 8. File Upload (type="file")
- 9. Date Picker (type="date")
- 10. Telephone Input (type="tel")
- 11. Search Input (type="search")
- Button and Submission Input Types
- 12. Submit Button (type="submit")
- 13. Reset Button (type="reset")
- Step-by-Step Explanation of the Form Code
- Form Setup (<form> tag)
- Name Field
- Email Field
- Password Field
- Date of Birth Field
- Gender Selection (Radio Buttons)
- File Upload Field
- Submit Button
- GET vs POST: Which Method Should You Use?
- Key Differences Between GET and POST
- Making Forms Accessible with HTML Attributes
- 2. Essential HTML Attributes for Form Accessibility
- 1️⃣ Labeling Inputs Properly (<label> & for Attribute)
- 2️⃣ Using aria-label for Better Screen Reader Support
- 3️⃣ Grouping Related Inputs (<fieldset> & <legend>)
- 4️⃣ Using aria-describedby for Additional Hints
- 5️⃣ Using required & aria-required for Mandatory Fields
- 6️⃣ Providing Clear Error Messages (aria-invalid & Live Alerts)
- 7️⃣ Using tabindex for Better Keyboard Navigation

Forms are an essential part of any website, allowing users to input and submit data. This guide will explain the basics of HTML forms, different input types, the difference between GET and POST methods, and how to make forms more accessible.
What is an HTML Form?
An HTML form is a section on a webpage that allows users to enter and submit information.
Example of a Simple HTML Form
<form action="submit.php" method="POST">
<label for="username">Username:</label>
<input type="text" id="username" name="username" required>
<label for="password">Password:</label>
<input type="password" id="password" name="password" required>
<button type="submit">Submit</button>
</form>
<form>
→ Defines the form.action="submit.php"
→ Specifies where to send the form data.method="POST"
→ Defines how the data is sent (we will discuss this later).<label>
→ Provides a description for an input field.<input>
→ Allows users to enter data.<button>
→ Submits the form.
HTML Input Types Explained :
HTML provides various input types to collect different types of data.
Common Input Types:
Input Type | Description | Example |
text | Single-line text input | <input type="text"> |
password | Hidden characters for passwords | <input type="password"> |
email | Requires a valid email format | <input type="email"> |
number | Allows only numbers | <input type="number"> |
tel | Input for phone numbers | <input type="tel"> |
checkbox | Allows multiple selections | <input type="checkbox"> |
radio | Allows only one selection per group | <input type="radio"> |
file | Allows file uploads | <input type="file"> |
date | Select a date | <input type="date"> |
GET vs POST: Which Method Should You Use?
When submitting a form, you need to decide whether to use GET or POST in the method
attribute.
GET Method
Appends form data to the URL.
Used for simple data retrieval (e.g., search forms).
Less secure (data is visible in the URL).
Limited data size.
Example:
🔹 If the user searches for "HTML Forms," the URL will look like:
📌 https://example.com/search.php?query=HTML+Forms
<form action="search.php" method="GET">
<input type="text" name="query">
<button type="submit">Search</button>
</form>
POST Method
Sends data in the request body (not visible in the URL).
Used for sensitive data (e.g., login forms).
Allows larger amounts of data.
More secure than GET.
Example:
- Data is not visible in the URL, making it more secure for handling login credentials.
<form action="login.php" method="POST">
<input type="text" name="username">
<input type="password" name="password">
<button type="submit">Login</button>
</form>
When to Use GET vs POST?
Feature | GET | POST |
URL Parameters | Visible | Hidden |
Security | Less Secure | More Secure |
Data Limit | Limited | No Limit |
Use Case | Search forms, filtering | Login, sensitive data |
HTML Input Types Explained: From Text to Passwords.
Making Forms Accessible with HTML Attributes :
Web accessibility ensures that people with disabilities can use forms easily. Here are some best practices:
<form action="submit.php" method="POST">
<label for="name">Name:</label>
<input type="text" id="name" name="name" required>
<label for="email">Email:</label>
<input type="email" id="email" name="email" required>
<label for="password">Password:</label>
<input type="password" id="password" name="password" required>
<label for="dob">Date of Birth:</label>
<input type="date" id="dob" name="dob">
<label for="gender">Gender:</label>
<input type="radio" id="male" name="gender" value="male"> Male
<input type="radio" id="female" name="gender" value="female"> Female
<label for="file">Upload a file:</label>
<input type="file" id="file" name="file">
<button type="submit">Submit</button>
</form>
In HTML, the <input>
element allows users to enter data into forms. There are multiple input types, each designed for a specific kind of data. This guide explains common HTML input types and how to use them effectively.
Basic Input Types
1. Text Input (type="text"
)
Used for single-line text input, such as names or usernames.
Accepts any alphanumeric characters.
2. Password Input (type="password"
)
Used for entering passwords.
The input is masked (dots or asterisks).
3. Email Input (type="email"
)
Accepts only valid email formats (e.g.,
example@mail.com
).Shows an error if an invalid email is entered.
4. Number Input (type="number"
)
Allows only numeric values.
You can set a minimum, maximum, and step value.
Selection Input Types
5. Radio Button (type="radio"
)
- Used for selecting one option from multiple choices.
6. Checkbox (type="checkbox"
)
- Allows users to select multiple options.
7. Dropdown (<select>
)
- Provides a list of options in a dropdown menu.
Special Input Types
8. File Upload (type="file"
)
- Allows users to upload files.
9. Date Picker (type="date"
)
- Allows users to select a date from a calendar.
10. Telephone Input (type="tel"
)
Used for entering a phone number.
You can use pattern validation for a specific format.
11. Search Input (type="search"
)
- Provides a search field.
Button and Submission Input Types
12. Submit Button (type="submit"
)
- Used to submit a form.
13. Reset Button (type="reset"
)
- Clears all inputs in a form.
Step-by-Step Explanation of the Form Code
Form Setup (<form>
tag)
The form acts as a container for all input fields.
It sends the entered data to
submit.php
for processing.The
POST
method is used to securely transmit user data.
Name Field
A label displays “Name” for user clarity.
A text input allows users to type their name.
The
required
attribute ensures users must fill in this field before submitting.
Email Field
A label guides the user to enter their email.
The email input only accepts valid email formats.
The
required
attribute enforces completion before form submission.
Password Field
A label prompts users to enter their password.
The password input masks user input for security.
The
required
attribute ensures the user must enter a password before proceeding.
Date of Birth Field
A label instructs users to enter their date of birth.
The date input allows easy selection from a calendar.
Gender Selection (Radio Buttons)
A label indicates gender selection.
Two radio buttons allow users to choose either "Male" or "Female."
Only one option can be selected at a time.
File Upload Field
A label informs users they can upload a file.
A file input lets users attach files (e.g., profile pictures, documents).
Submit Button
- A button is provided for users to submit the completed form.
GET vs POST: Which Method Should You Use?
When submitting forms or sending data to a server, GET and POST are the two most commonly used HTTP methods. Each method has different use cases, advantages, and security considerations.
What is GET?
The GET method is used to retrieve data from a server.
How it Works:
The form data is appended to the URL as query parameters (e.g.,
example.com
?name=John&age=25
).The request is visible in the browser’s address bar.
GET requests are cached and can be bookmarked.
Example: Using GET in an HTML Form
<form action="process.php" method="GET">
<input type="text" name="name" placeholder="Enter your name">
<button type="submit">Submit</button>
</form>
- If a user enters John, the browser sends a request like:
process.php?name=John
What is POST?
The POST method is used to send data to the server for processing, like submitting a login form or storing data in a database.
How it Works:
The form data is sent in the request body (not visible in the URL).
Data is not cached or stored in the browser history.
It can handle large amounts of data and file uploads.
Example: Using POST in an HTML Form
<form action="process.php" method="POST">
<input type="text" name="name" placeholder="Enter your name">
<button type="submit">Submit</button>
</form>
- If a user enters John, the request is sent securely in the body, not visible in the URL.
Key Differences Between GET and POST
Feature | GET | POST |
Data Visibility | Visible in the URL | Hidden in the request body |
Security | Less secure (data can be seen in the browser) | More secure (data is not stored in the URL) |
Data Size | Limited (2048 characters in most cases) | No size limit (depends on server settings) |
Caching | Can be cached | Not cached |
Use Case | Fetching data, search queries, navigation | Login forms, sensitive data, file uploads |
Making Forms Accessible with HTML Attributes
1. Why is Form Accessibility Important?
Helps visually impaired users who rely on screen readers.
Improves keyboard navigation for users who cannot use a mouse.
Makes forms easier to understand and use for all users.
Ensures compliance with web accessibility standards (e.g., WCAG [Web Content Accessibility Guidelines]).
2. Essential HTML Attributes for Form Accessibility
1️⃣ Labeling Inputs Properly (<label>
& for
Attribute)
The
<label>
element associates a text label with an input field.The
for
attribute should match the input’sid
to create a clear connection.Helps screen readers announce the purpose of the input.
2️⃣ Using aria-label
for Better Screen Reader Support
The
aria-label
attribute provides a hidden label for screen readers.Useful when a visible label is not present (e.g., search bars, icon buttons).
3️⃣ Grouping Related Inputs (<fieldset>
& <legend>
)
The
<fieldset>
element groups related inputs together.The
<legend>
provides a descriptive title for the group.
4️⃣ Using aria-describedby
for Additional Hints
The
aria-describedby
attribute links an input to helpful instructions.Useful for explaining special formatting (e.g., passwords, phone numbers).
5️⃣ Using required
& aria-required
for Mandatory Fields
The
required
attribute ensures a field must be filled before submission.The
aria-required="true"
helps screen readers announce mandatory fields.
6️⃣ Providing Clear Error Messages (aria-invalid
& Live Alerts)
The
aria-invalid="true"
attribute marks invalid inputs.The
role="alert"
attribute immediately announces error messages.
7️⃣ Using tabindex
for Better Keyboard Navigation
The
tabindex
attribute controls keyboard focus order.Use
tabindex="0"
to include an element in the normal tab order.Use
tabindex="-1"
to remove an element from tab order.
Subscribe to my newsletter
Read articles from Maulik Gajipara 🏌️ directly inside your inbox. Subscribe to the newsletter, and don't miss out.
Written by
