Syntax | <input /> |
---|---|
Attribute Specifications |
|
Contents | Empty |
Contained in | Block-level elements, inline elements except button |
The input element defines a form control for the user to enter input. While input is most useful within a form, XHTML 1.0 allows input in any block-level or inline element other than button. However, Netscape Navigator 4.x and earlier will not display any input elements outside of a form.
When a form is submitted, the current value of each input element within the form is sent to the server as name/value pairs. The input element's name attribute provides the name used. The value sent depends on the type of form control and on the user's input.
The type of form control defined by input is given by the type attribute. The default type is text, which provides a single-line text input field. The value attribute specifies the initial value for the text field. The size and maxlength attributes suggest the number of characters and maximum number of characters, respectively, of the text field.
While the maxlength attribute can be an effective guide to the user, authors should not depend on the enforcement of a maximum number of characters by the client. A user could copy the XHTML document, remove the maxlength attribute, and submit the form. Thus authors of form handlers should ensure that any necessary input length checks are repeated on the server-side.
The password input type is a variation on the text type. The only difference is that the input characters are masked, typically by a series of asterisks, to protect sensitive information from onlookers. Note, however, that the actual value is transmitted to the server as clear text, so password inputs do not provide sufficient security for credit card numbers or other highly sensitive information.
The following example uses text and password fields with the label element to bind text labels to the input elements:
<p><label
accesskey="u">User Name: <input type="text"
name="username" size="8" maxlength="8"
/></label></p>
<p><label accesskey="p">Password: <input
type="password" name="pw" size="12" maxlength="12"
/></label></p>
The boolean readonly attribute, new in HTML 4.0 and poorly supported by current browsers, prevents the user from editing the content of the text or password input types. Read-only elements are still submitted with the form. The disabled attribute, which applies to all input types but is also poorly supported, disables the control. Disabled elements are read-only elements with the added restrictions that the values are not submitted with the form, the elements cannot receive focus, and the elements are skipped when navigating the document by tabbing.
The radio and checkbox input types provide switches that can be turned on and off by the user. The two types differ in that radio buttons are grouped (by specifying the same name attribute on each input) so that only one radio button in a group can be selected at any time. Checkboxes can be checked without changing the state of other checkboxes with the same name. The value attribute, required for radio buttons and checkboxes, gives the value of the control when it is checked. The boolean checked attribute specifies that the control is initially checked.
Some browsers require one radio button in a group to be selected at all times. To ensure that an appropriate default choice is made, authors may wish to define one of the radio input elements as checked.
In the following example, only one payment method may be selected by the user since the radio buttons have the same name:
<p>Please indicate your method of
payment:</p>
<p><label accesskey="c"><input type="radio"
name="payment_method" value="Credit Card" checked="checked"
/> Credit Card</label><br />
<label accesskey="d"><input type="radio"
name="payment_method" value="Debit Card" /> Debit
Card</label><br />
<label accesskey="m"><input type="radio"
name="payment_method" value="Money Order" /> Money
Order</label></p>
<p><label
accesskey="s"><input type="checkbox"
name="send_receipt" value="yes" checked="checked" />
Send receipt by email</label></p>
The file input type creates a field through which users can upload files from their local computer or network. The value attribute specifies the name of the initial file, but it is typically ignored by browsers as a security precaution. The accept attribute gives a comma-separated list of media types accepted, allowing the browser to filter out inappropriate files. Current browsers generally ignore the accept attribute.
A form that includes a file input must specify method="post" and enctype="multipart/form-data" in the <form> tag. CGI libraries such as CGI.pm allow simple handling of such forms.
Form-based file upload is unsupported by many currently deployed browsers. Authors should provide alternative methods of input where possible.
The following example allows the user to upload an XHTML document for validation:
<form method="post"
action="/cgi-bin/validate.cgi"
enctype="multipart/form-data">
<p>Select an XHTML document to upload and validate. If your
browser does not support form-based file upload, use one of our
<a href="methods.html">alternate methods of
validation</a>.</p>
<p><input type="file" name="html_file"
accept="text/html" /></p>
<p><input type="submit" value="Validate It!"
/></p>
</form>
allows authors to include form data without having it rendered to the user. This is particularly useful in form applications that span several XHTML documents; user input can be carried from form to form by hidden inputs. Some generalized CGI scripts use hidden inputs to define variables for the script, as in the following example, which defines a recipient and subject for the e-mailed contents of a form:
<input type="hidden"
name="recipient" value="liam@htmlhelp.com" />
<input type="hidden" name="subject" value="Feedback on your
XHTML reference" />
Note that the fields are "hidden" in the sense that they are not rendered by the browser. Anyone can still view the XHTML document's source to find the "hidden" fields.
The type value reset defines a button by which the user can reset the form to its initial values. The optional value attribute of a reset button overrides the browser's default text for the button.
The submit input type defines a button for submitting the form. As with reset, the optional value attribute provides the text of the button. The presence of the name attribute will cause the browser to send a name/value pair for the submit button if it is used to submit the form. This allows authors to provide multiple submit buttons and have the form handler take a different action depending on the submit button used.
The image input type specifies a graphical submit button. The src attribute must be included to specify the URI of the image. The alt attribute should be used to give replacement text for those not loading images. alt is a new addition in HTML 4.0; many browsers rely on either the name or value attribute as alternate text, so authors should use all three attributes for the same purpose where possible. The topic of graphical submit buttons for text users is discussed in detail in the article INPUT TYPE=IMAGE for text users?.
When the graphical submit button is clicked, the coordinates of the click are sent with the form submission as name.x=x-value and name.y=y-value where name is the value of the name attribute, x-value is the click's pixels from the left of the image, and y-value is the click's pixels from the top of the image. The usemap attribute combined with type=image defines a client-side image map that can be used with client-side scripting, but this method is poorly supported. The usemap attribute gives the URI of the defining map.
The deprecated align attribute specifies the alignment of the graphical submit button. The values top, middle, and bottom specify the button's position with respect to surrounding content on its left and right. The values left and right specify a floating button; the image is placed at the left or right margin and content flows around it. To place content below the button, use <br clear="left"|"right"|"all"> or the CSS clear property on the next element as appropriate.
The vertical-align and float properties of Cascading Style Sheets provide more flexible methods of aligning buttons.
The input type button specifies a push button for use with client-side scripting. The value attribute gives the text label of the button. The onclick attribute is typically used to define the action taken when the button is activated. An example follows:
<input type="button"
value="Hide non-strict attributes" id="toggler" onclick="toggle()"
/>
In this example, the toggle() function, which would be defined earlier in a script element, will be executed when the button is clicked. Since the button is only useful with client-side scripting enabled, authors should usually output the <input type="button" /> tag using the scripting language to avoid providing a non-functioning button to some users. A more complete version of the previous example would thus be as follows:
<script type="text/javascript">
<!-- document.write("<input type="button" value=\"Hide non-strict attributes\"" + "id="toggler" onclick=\"toggle()\" />"); // -->
</script>
The button element allows richer labels for submit, reset, and push buttons, but a lack of browser support makes input a more reliable choice at this time.
The accesskey and tabindex attributes apply to all input types except hidden. accesskey specifies a single Unicode character as a shortcut key for giving focus to the form control. Authors can set the access key on the input element or the label element associated with it. Entities (e.g. é) may be used as the accesskey value.
The tabindex attribute specifies a number between 0 and 32767 to indicate the tabbing order of the element. A form control with tabindex="0" or no tabindex attribute will be visited after any elements with a positive tabindex. Among positive tabindex values, the lower number receives focus first. In the case of a tie, the element appearing first in the XHTML document takes precedence.
The ismap attribute is used with server-side image maps. When the ismap attribute is included with a image input type and the user clicks the image, the image coordinates clicked are sent to the server, from which a location can be returned. The method of handling the coordinates is server-dependent, but the NCSA server's method is most common.
The input element also takes a number of attributes to specify client-side scripting actions for various events. In addition to the core events common to most elements, input accepts the following event attributes: