Syntax | <label>...</label> |
---|---|
Attribute Specifications |
|
Contents | Inline elements except label |
Contained in | Block-level elements, inline elements except button |
The label element associates a label with a form control. By associating labels with form controls, authors give important hints to users of speech browsers while also allowing visual browsers to duplicate common GUI features (e.g., the ability to click on a text label to select a radio button or checkbox).
Each label element is associated with exactly one form control. The element's content is the label of the form control and may include inline elements such as img and strong.
The for attribute explicitly specifies the control associated with the label. The value of the for attribute must match the value of the associated form control's id attribute. In the absence of the for attribute, the label must contain the associated form control. This method of implicit association is convenient in many cases, but not an option when the form control and its label are in different table cells, paragraphs, or divisions. The following example illustrates both explicit and implicit label associations:
<table>
<tr>
<td>
<label for="user" accesskey="u">User</label>
</td>
<td>
<select name="user" id="user">
<option>Jean</option>
<option>Kim</option>
<option>Brian</option>
</select>
</td>
</tr>
<tr>
<td><label for="passwd" accesskey="p">Password</label></td>
<td><input type="password" name="password" id="passwd" /></td>
</tr>
</table>
<p>
<label accesskey="s">
<input type="checkbox" name="save" value="yes" />
Save user name and password in a cookie
</label>
</p>
<p>
<label accesskey="c">
Comments to post:
<textarea name="comments" rows="8" cols="50"></textarea>
</label>
</p>
The accesskey attribute, used throughout the preceding example, specifies a single Unicode character as a shortcut key for giving focus to the label, which passes the focus on to the associated form control. Entities (e.g. é) may be used as the accesskey value.
The label 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, label accepts the following event attributes: