input (type=text) element
If you don't know what an element is or how you must use it, I recommend you read the "HTML tags and attributes" tutorial that you can find in the HTML tutorials section.
Table of contents
Description
The input
element, having the "text" value in its type
attribute, represents a field for text input. The control associated to this field is a text box that allows users to edit a single line of plain text. Text controls are useful to gather short runs of text like titles, mames, surnames, short descriptions, keywords, tags, etc.
Examples
In our first example we'll create a form
with three text input controls. As we're almost certain that the user browsing the page is John, we'll place his name in the value
attribute of the first control.
In the third control, we'll make use of the placeholder
attribute, which has been introduced in HTML5. This attribute allows us to give a hint about the data that's expected to be provided in the control, like examples or short descriptions. This hint will be displayed inside the control (as if it were the value) only while the control has no real value. When the user starts typing, the placeholder
text will be removed from the control.
<form action="../../form-result.php" method="post" target="_blank">
<p>First name: <input type="text" name="firstname" value="John"></p>
<p>Last name: <input type="text" name="lastname"></p>
<p>Favorite sport: <input type="text" name="sport" placeholder="Football? Tennis? Hockey?"></p>
<p>
<input type="submit" value="Send data">
<input type="reset" value="Reset form">
</p>
</form>
In the second example, we'll use some other attributes: size
to establish the width of the control as a number of visible characters and maxlength
to set the maximum number of characters the value may have.
<form action="../../form-result.php" method="post" target="_blank">
<p>
Enter your code: <input type="text" name="code" size="4" maxlength="4">
<input type="submit" value="Send data">
</p>
</form>
In our third example, we'll explore a couple of attributes that can be mistakenly seen as having the same effect. The first attribute is readonly
which prevents the user from editing the value of the control, yet allowing him to select and copy its text. The attribute disabled
, in the other hand, goes further by not allowing the user to select or copy its text and plus prevents the value of the element to be sent when the form is submitted.
Here you'll be able to see how these attributes affect the interacition and, specially, how the data is submitted (or not submitted) to the server.
<form action="../../form-result.php" method="post" target="_blank">
<p>Read only text: <input type="text" name="readonlytext" value="Hi!" readonly></p>
<p>Disabled text: <input type="text" name="disabledtext" value="Ho!" disabled></p>
<p><input type="submit" value="Send data"></p>
</form>
Now let's check another new attribute in HTML5: list
. This attribute links the control to a datalist
element by referencing its id
attribute. The associated datalist
provides a number of suggestions that users can pick to automatically fill the control's value.
<form action="../../form-result.php" method="post" target="_blank">
<p>
Model: <input type="text" name="model" list="modelslist">
<input type="submit" value="Send data">
</p>
</form>
<datalist id="modelslist">
<option value="Camaro">
<option value="Corvette">
<option value="Impala">
<option value="Colorado">
</datalist>
Our final example combines two attributes, also new in HTML5, that usually work well together. These are pattern
and required
. Their importance becomes evident when the author needs to set rules about the format of data that can be input in a control.
The pattern
attribute, helps by estabishing a regular expression that any input value must comply with. When it's set, the title
attribute takes particular relevance, as it's responsible of providing an explanation about the rules that apply on the field. Browsers may use this information to compose the error message shown to the user after an unsuccessful submission.
In the other hand, the required
attribute disallows users to leave the field empty. Both attributes, together, indicate that the control must be filled and specify how it must be filled.
<form action="../../form-result.php" method="post" target="_blank">
<p>
Security code: <input type="text" name="seccode" pattern="[A-Za-z0-9]{8,20}" title="A valid security code consist of a string with 8 to 20 characters, each of which is a letter or digit" required>
<input type="submit" value="Send data">
</p>
</form>
Attributes
Specific attributes
autofocus
A boolean value instructing the browser to set the focus to this control when the document has finished loading or when the dialog
where the control finds itself is shown. If the attribute has the value "autofocus" or the empty string (""), or if it's just present, the control should get the focus as soon as possible, after the page or dialog
has been loaded.
Example
<p>Enter you username: <input type="text" name="username" autofocus></p>
dirname
A name for a new field specially created to transmit the directionality of the input text. This attribute, new in HTML5, allows authors to handle correctly values submitted with any text directionality, by adding a field that's submitted with the form. The name for that field will be the value of this attribute.
Being relatively new, browser support for the dirname
attribute is incomplete. Authors should check for support when the data is received server-side.
Example
<form action="../../form-result.php" method="post" target="_blank">
<p>
Some text: <input type="text" name="sometext" dirname="sometext-dir">
<input type="submit" value="Send data">
</p>
</form>
disabled
A boolean value indicating wether the control is disabled or not. If the attribute takes the value "disabled" or the empty string (""), or if it's just present, the control will be disabled.
Disabled controls are rendered greyed out (if visible), are blocked from user interaction and, more importantly, their values (if any) aren't sent when the form
is submitted.
Example
<form action="../../form-result.php" method="post" target="_blank">
<p>
Some text: <input type="text" name="sometext" disabled>
<input type="submit" value="Send data">
</p>
</form>
form
The value of the id
attribute of the form with which this control is associated to.
This attribute is new in HTML5 and helps defining the pertenence of controls in nested or distant forms.
Example
<p>Some text: <input type="text" name="sometext" form="form1"></p>
<form id="form1" action="../../form-result.php" method="post" target="_blank">
<p><input type="submit" value="Send data"></p>
</form>
Some text:
list
A token matching the value of the id
attribute of the datalist
this control is assopciated with. The datalist
referenced by this attribute will provide a number of suggestions that users can pick to autocomplete the control.
Browser support for datalist
is incomplete. Authors may have to rely on scripts to provide this functionality cross-browser.
Example
<form action="../../form-result.php" method="post" target="_blank">
<p>
Favorite pet: <input type="text" name="favoritepet" list="petslist">
<input type="submit" value="Send data">
</p>
</form>
<datalist id="petslist">
<option value="Dog">
<option value="Cat">
<option value="Bunny">
<option value="Parrot">
</datalist>
maxlength
An integer indicating the maximum number of characters the value of this control may have.
Authors shouldn't rely on the maxlength
attribute. Users can always submit the form
with browsers (some intentionally) not supporting this feature.
Example
<form action="../../form-result.php" method="post" target="_blank">
<p>
Enter your code: <input type="text" name="code" maxlength="2">
<input type="submit" value="Send data">
</p>
</form>
minlength
An integer indicating the minimum number of characters the value of this control may have.
Authors shouldn't rely on the minlength
attribute. Users can always submit the form
with browsers (some intentionally) not supporting this feature.
Browser support for the minlength
attribute is extremely low (as of 2014/12/18). Authors shouldn't rely on this attribute until support grows.
Example
<form action="../../form-result.php" method="post" target="_blank">
<p>
Enter your code: <input type="text" name="code" minlength="1">
<input type="submit" value="Send data">
</p>
</form>
name
A name for the control. This name will be sent by the browser to the processing agent, paired with the content of the value
attribute. Both attributes together will conform a name-value pair that will be used to process the form data.
Currently, the value isindex
, formerly used in a special way by some browsers and included in the HTML standard, isn't permitted in this attribute.
Example
<form action="../../form-result.php" method="post" target="_blank">
<p>
Enter your city: <input type="text" name="city">
<input type="submit" value="Send data">
</p>
</form>
pattern
A regular expression to match against the control's value before the form
is submitted. This attribute can be used to specify a format that users will have to comply with when filling the field. If this pattern isn't respected, an error message will be shown upon submission and the process will be cancelled (unless the formnovalidate
attribute is present in the form
or submission button).
The title
attribute takes a special meaning when this attribute is present: it's expected to provide an explanation about the rules that apply on the field. Browsers may use the information in title
to compose the error message shown to the user when the process of submission is cancelled.
A regular expression is a sequence of characters that forms a search pattern, mainly for use in pattern matching with strings or search-and-replace like operations.
Example
<form action="../../form-result.php" method="post" target="_blank">
<p>
Enter your code: <input type="text" name="code" pattern="[A-Z0-9]{4,10}" title="A valid code must have 4 to 10 characters in length, where each character can be an uppercase letter or a digit">
<input type="submit" value="Send data">
</p>
</form>
placeholder
A run of text that's supposed to provide a hint about how the field should be filled in, like examples or short descriptions. Browsers may display the contents of this attribute in the control while it has no value. As soon as users start to write down their own text, the placeholder
text should dissapear from the control.
Authors shouldn't use this attribute to replace the label. Labels are suposed to provde a title, while the placeholder should give a small hint about how to fill the field. Morover, the placeholder text is expected to disapear when the user starts typing in the control.
Example
<form action="../../form-result.php" method="post" target="_blank">
<p>
State: <input type="text" name="state" placeholder="Kansas, Arizona, Colorado...">
<input type="submit" value="Send data">
</p>
</form>
readonly
A boolean value instructing the browser to prevent the user from changing the control's value. If this attribute has the value "readonly" or the empty string (""), or if it's just present, the user won't be allowed to change the value in the control.
Although this attribute prevents the control's value from being edited, not all interaction is blocked: users will still be able to select and copy the text in the control.
Example
<form action="../../form-result.php" method="post" target="_blank">
<p>
Username: <input type="text" name="username" value="samwise4855" readonly>
<input type="submit" value="Send data">
</p>
</form>
required
A boolean value indicating wether this control can be left empty or not. If this attribute has the value "required" or the empty string (""), or if it's just present, the user will have to fill the control in order to be able to submit the form
.
If a control with the required
attribute present is left blank, supporting browsers will throw an error upon submission and cancel the process immediately.
Browser support for the attribute required
is incomplete. Authors may have to rely on scripts to provide this functionality cross-browser.
Example
<form action="../../form-result.php" method="post" target="_blank">
<p>
Title: <input type="text" name="title" required>
<input type="submit" value="Send data">
</p>
</form>
size
An integer to use as width of the element, in number of characters that should be visible in the control simultaneously.
As characters usually don't have the same width, browsers may define a character witdth according to certain criteria (like average or maximum width).
Example
<form action="../../form-result.php" method="post" target="_blank">
<p>
Code: <input type="text" name="code" size="4">
<input type="submit" value="Send data">
</p>
</form>
type
A value indicating the type of the field that this element represents. There are twenty two possible values (case-insensitive):
- hidden: a hidden control used to send information to the server, typically managed by scripts.
- text: a control used to input a single-line piece of text.
- search: same as text but for search purposes.
- tel: a control used to provide a telephone number.
- url: a text box used to input a single and absolute URL.
- email: a control designed to edit one or more e-mail addresses.
- password: a text box for editing passwords, where the characters are represented by dots.
- date: a control to input a specific date.
- month: a control to input a specific month.
- week: a control to input a specific week.
- time: a control to input a specific time.
- datetime-local: a control to input a specific local date and time.
- number: a control to input a number.
- range: a control to input one or two numbers inside a range.
- color: a control to input a color.
- checkbox: a control to input a boolean value (true/false).
- radio: a control used to choose one single option among many.
- file: a control used to upload files to the server.
- submit: a button used to submit the form.
- image: same as submit but with the ability to be shown as an image instead of using the default button appearance.
- reset: a button used to reset the form's controls to their default values.
- button: a button with no default action associated.
When this attribute isn't present, the element behaves as it would have the value "text".
Example
<input type="text" name="dataname">
value
An initial value for the control, that will be set when the page loads and when the reset button is pressed.
Example
<form action="../../form-result.php" method="post" target="_blank">
<p>Title: <input type="text" name="title" value="A man without honor"></p>
<p>
<input type="submit" value="Send data">
<input type="reset" value="Reset form">
<p>
</form>
Global attributes
For information about global attributes refer to this list of global attributes in HTML5.
Events
Global events
For information about global events refer to this list of global events in HTML5.