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

Table of contents

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 TypeDescriptionExample
textSingle-line text input<input type="text">
passwordHidden characters for passwords<input type="password">
emailRequires a valid email format<input type="email">
numberAllows only numbers<input type="number">
telInput for phone numbers<input type="tel">
checkboxAllows multiple selections<input type="checkbox">
radioAllows only one selection per group<input type="radio">
fileAllows file uploads<input type="file">
dateSelect 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?

FeatureGETPOST
URL ParametersVisibleHidden
SecurityLess SecureMore Secure
Data LimitLimitedNo Limit
Use CaseSearch forms, filteringLogin, 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

FeatureGETPOST
Data VisibilityVisible in the URLHidden in the request body
SecurityLess secure (data can be seen in the browser)More secure (data is not stored in the URL)
Data SizeLimited (2048 characters in most cases)No size limit (depends on server settings)
CachingCan be cachedNot cached
Use CaseFetching data, search queries, navigationLogin 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’s id 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).

  • 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.

0
Subscribe to my newsletter

Read articles from Maulik Gajipara 🏌️ directly inside your inbox. Subscribe to the newsletter, and don't miss out.

Written by

Maulik Gajipara 🏌️
Maulik Gajipara 🏌️