HTML Input Types


Lets dive into the versatile world of input types

12 May, 2020 · 4 min read

Today I want to spend some time going back to the basics of HTML, let’s see what kind of input elements we have and how we can leverage them.

The different input types

  • text
  • email
  • hidden
  • number
  • range
  • password
  • submit
  • checkbox
  • radio
  • file
  • date
  • color
  • tel
  • url

Yes, we have many, many options of input elements which we can leverage, let’s start going through all of these and see how they work and what they can be used for.

Input element

The input element is probably the most well known element and used by everyone, every login form or cms form uses it.

<input />

As you can see above it’s a self closing element.

<input type="text" />

We normally use a type specified for this input and a browser can add its default validation based on what you added here.

<input type="text" name="firstname" />

We can define the name attribute on an input, this is what would get send through to the backend and how we can then check what its value would be.

<input type="text" name="firstname" placeholder="Firstname" />

The placeholder attribute is used to have a small text show up when the input doesn’t have a value yet.

<input type="text" name="firstname" placeholder="Firstname" required />

We can add required to our input type and make it required by default, the browser can handle this for us.

<input type="text" name="firstname" placeholder="Firstname" pattern="[a-zA-Z0-9]+" />

We can define a default pattern, this accepts a regex and can help with the default validation. You can find some useful examples on html5pattern.

<input type="text" name="firstname" placeholder="Firstname" disabled />

We can add an attribute if we want the element to be disabled from input.

<input type="text" name="firstname" placeholder="Firstname" readonly />

We can also make an element readonly. This will make it also not-changeable.

Email input type

As mentioned above we can have different types of basic input, one of these being email. A browser can now determine if the user filled out a valid email address. We can use it as such:

<input type="email" name="email" placeholder="Email Address" />

Hidden input type

Another input type that I tend to use a lot is the hidden type, it will not show by default and is perfect to hold a cookie, or token which a user doesn’t even need to see.

<input type="hidden" name="hidden_cookie" value="SECRET_COOKIE" />

Number input type

We can also set the type to be a number and even define three more attributes being: min, max and step

<input type="number" name="number" placeholder="Amount?" min="5" max="15" step="5" />

Range input type

Much like the number one, we have a range type, it defines a range between a minimum and maximum number and can optionally include a step.

<input type="range" name="age" min="0" max="100" step="2" />

Password input type

The password type we have all seen before and it’s that one that makes the input turn into *** so people don’t see what you typed.

<input type="password" name="password" placeholder="Password" />

Submit input type

We can set the type to be submit to act as our submit button, we set the value to show what is in the button:

<input type="submit" value="Send form" />


Another great addition is the checkbox, as the name suggests it renders one or more checkbox. With a checkbox we can select one or multiple correct answers.

<input type="checkbox" name="dislike" value="Sprouts" />
<input type="checkbox" name="dislike" value="Fish" />
<input type="checkbox" name="dislike" value="Spinach" />

Radio input type

The radio input type is very much like the checkbox, but we can only select one option, per name!

<input type="radio" name="you_like" value="Pony" />
<input type="radio" name="you_like" value="Unicorn" />
<input type="radio" name="you_like" value="Llama" />

File input type

The file input type is a really extensive one and has many options for it. In basics, we can use it as follows:

<input type="file" name="files" multiple accept=".jpg, .jpeg" />

As you can see, we are using the multiple attribute, which makes it allow multiple files at once.

And we define what types it can accept by default.

Date input type

The date type is absolutely amazing, it shows a default date picker even!

<input type="date" name="date_of_birth" />

In the date elements we also have time, this will show a nice time picker.

<input type="time" name="time_online" />

Or define a month or week even:

<input type="month" name="month" /> <input type="week" name="week" />

Color input type

Another one that you barely seem used, but is so cool is the color input type. It comes with a basic color picker!

<input type="color" name="favorite_color" value="#F4F4F4" />

Tel input type

Tel input can be used to define a telephone number, it will show a different keyboard on mobile devices and adds basic validation for the browser.

<input type="tel" name="telephone" placeholder="Telephone" />

URL input type

This one can be used to define a URL, it shows a slightly different keyboard, but doesn’t come with much cool stuff.

<input type="url" name="website" placeholder="Your website?" />


As always feel free to play around with this Codepen where I added all the input types.

See the Pen HTML Input Types by Chris Bongers (@rebelchris) on CodePen.

Thank you for reading, and let’s connect!

Thank you for reading my blog. Feel free to subscribe to my email newsletter and connect on Facebook or Twitter

Spread the knowledge with fellow developers on Twitter
Tweet this tip
Powered by Webmentions - Learn more

Read next 📖

Submit button outside the form

4 Dec, 2022 · 1 min read

Submit button outside the form

Trying out native dialog modals

8 Aug, 2022 · 3 min read

Trying out native dialog modals

Join 2099 devs and subscribe to my newsletter