HTML Input Types

— 11 minute 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 permalink

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

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 permalink

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 permalink

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 permalink

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 permalink

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 permalink

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 permalink

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" />

Checkbox permalink

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 permalink

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 permalink

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 permalink

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 permalink

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 permalink

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 permalink

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?" />

Demo permalink

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! permalink

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