The <input>
element is used to create interactive controls for web-based forms to accept data from the user. Various types of input data and control widgets are available, depending on what use you need. The <input>
element is one of HTML's most powerful and complex. The DOM HTMLInputElement
interface provides the properties and methods for working with the options, layout, and presentation of <input>
elements.
Additional features
Labels
Labels are needed to associate assistive text with an <input>
. The <label>
element provides explanatory information about a form field that is always appropriate (aside from any layout concerns you have). It's never a bad idea to use a <label>
to explain what should be entered into an <input>
or <textarea>
.
Associated labels
The semantic pairing of <input>
and <label>
elements is useful for assistive technologies such as screen readers. By pairing them using the <label>
's for
attribute, you bond the label to the input in a way that lets screen readers describe inputs to users more precisely.
It does not suffice to have plain text adjacent to the <input>
element. Rather, usability and accessibility requires the inclusion of either implicit or explicit <label>
:
<!-- inaccessible --> <p>Enter your name: <input id="name" type="text" size="30" /></p> <!-- implicit label --> <p> <label>Enter your name: <input id="name" type="text" size="30" /></label> </p> <!-- explicit label --> <p> <label for="name">Enter your name: </label> <input id="name" type="text" size="30" /> </p>
The first example is inaccessible: no relationship exists between the prompt and the <input>
element.
In addition to an accessible name, the label provides a larger 'hit'
area for mouse and touch screen users to click on or touch. By pairing a
<label>
with an <input>
, clicking on either one will focus the <input>
.
If you use plain text to "label" your input, this won't happen. Having
the prompt part of the activation area for the input is helpful for
people with motor control conditions.
As web developers, it's important that we never assume that people will know all the things that we know. The diversity of people using the web-and by extension your website-practically guarantees that some of your site's visitors will have some variation in thought processes and/or circumstances that leads them to interpret your forms very differently from you without clear and properly-presented labels.
Placeholders are not accessible
The placeholder
attribute lets you specify text that appears within the <input>
element's content area itself when it is empty. The placeholder should
never be required to understand your forms. It is not a label, and
should not be used as a substitute, because it isn't. The placeholder is
used to provide a hint as to what an inputted value should look like,
not an explanation or prompt.
Not only is the placeholder not accessible to screen readers, but
once the user enters any text into the form control, or if the form
control already has a value, the placeholder disappears. Browsers with
automatic page translation features may skip over attributes when
translating, meaning the placeholder
may not get translated.
Note: Don't use the placeholder
attribute if you can avoid it. If you need to label an <input>
element, use the <label>
element.
Localization
The allowed inputs for certain <input>
types depend on the locale. In some locales, 1,000.00 is a valid
number, while in other locales the valid way to enter this number is
1.000,00.
Firefox uses the following heuristics to determine the locale to validate the user's input (at least for type="number"
):
- Try the language specified by a
lang
/xml:lang
attribute on the element or any of its parents. - Try the language specified by any
Content-Language
HTTP header. Or, - If none specified, use the browser's locale.