http://warc.calpoly.edu/accessibility/508indepth/forms.html
The law states:
"When electronic forms are designed to be completed on-line, the form shall allow people using assistive technology to access the information, field elements, and functionality required for completion and submission of the form, including all directions and cues."
Forms must be created with accessibility and usability in mind, there are a number of factors that contribute to the accessibility and usability of forms, including layout, labeling and grouping. Different form elements need different kinds of markup to be accessible.
All important information for forms, such as form instructions, must be presented before the form itself. The submit button must be the last form element contained within a form.
Screen readers and other adaptive technology access forms and other HTML content in a linear order. Once a screen reader encounters a submit button, the user generally expects that the form should be submitted. In cases where optional fields, such as radio buttons for changing search criteria, are presented after the submit button, the screen-reader user may not be aware that the options even exist, or will discover them after-the-fact.
Similarly, instructions for a form must be presented before the form. This includes statements about how required fields are denoted or information that the person should be aware of before submitting the form.
A best practice is to group common form elements using the fieldset tag.
Use the label
tag to associate a meaningful text label with every text entry field. The text label is read by screen reader technology thus announcing the meaning of the text entry field that follows it. The text label description should be written in a way to help users understand the type of information they should input into each field. There are two methods for associating text labels with text entry fields.
One way is to have the input
tag encapsulated within the label
tag. This method will put the text label right next to the text entry field.
HTML Code: <label>First Name: <input type="text" /> </label>
If you need to have the text label and text entry field separate, use the for
and the id
attributes to connect the items together. The id
attribute of the input tag gives the form element an identification. The for
attribute of the label
tag connects the text label to the specific identification that was setup in the input
tag. You might need to do this when you are using tables for layout to put the label and text field in different columns or rows.
HTML Code:
<label for="lname1">Last Name:</label>
<input name="lastname" id="lname1" type="text" />
<br />
<label for="fname1">First Name:</label>
<input name="firstname" id="fname1" type="text" />
Radio buttons and check boxes work in the same way as text areas do. You can either have the input
tag inside the label
tag or use the for
and the id
attributes. Both methods produce the same look. Radio buttons and check boxes should have the input first then the label.
HTML Code:
<input type="radio" value="male" id="male">
<label for="male">Male</label>
<input type="radio" value="female" id="female">
<label for="female">Female</label>
<label><input type="radio" value="male" id="male">Male</label>
<label><input type="radio" value="female" id="female">Female</label>
Group together multiple form elements that are of related information using thefieldset
tag, and label it with the legend
tag. For example, group radio buttons or check boxes in the same category. Visually, this makes more sense to viewers, but also, when a screen reader goes through a form grouped with the fieldset
andlegend
tags, it will read the legend followed by the form element within the grouping. The form below will be read as: Personal Information, First Name, Personal Information, Last Name, Hobbies, Sports, Music, Video Games, Reading.
HTML Code:
<fieldset>
<legend>Personal Information</legend><br />
<label for="fname">First Name:</label>
<input type="text" name="first name" id="fname"><br />
<label for="lname">Last Name:</label>
<input type="text" name="last name" id="lname">
</fieldset>
<fieldset>
<legend>Hobbies:</legend><br />
<input id="sports" type="checkbox" value="checkbox">
<label for="sports">Sports</label><br />
<input id="music" type="checkbox" value="checkbox">
<label for="music">Music</label>
<input id="video games" type ="checkbox" value="checkbox">
<label for="video games">Video Games</label>
<input id="reading" type="checkbox" value="checkbox">
<label for="reading">Reading</label>
</fieldset>
Best practices:
HTML Code:
<label for="tshirtsize">Your T-shirt size</label>
<select id="tshirtsize">
<option value="xlarge" selected="selected">Extra Large</option>
<option value="large">Large</option>
<option value="medium">Medium</option>
<option value="small">Small</option>
</select>
Jump menus (select lists which activate as soon as the user selects an item) are totally inaccessible to screen reader users. A "Go" button needed to allow the user to execute the menu selection.
The following select list is accessible as it requires the user to click on the "Go" button:
By having the 'Go' button it allows the form to be activated with Javascript a server-side script (e.g. with PHP or ASP).
HTML code:
<label for="jumpto">Quick links</label><br />
<select id="jumpto">
<option>About us</option>
<option>Contact us</option>
<option>Jobs</option>
<option>People</option>
</select>
<input type="button" value="Go" />
Reference WebAIM for building accessible select lists
To make regular HTML based forms buttons accessible, remember to use the value attribute. The text of the value attribute will be read by the screen reader technology. It is not necessary to use the <label> tag with form buttons. The text of the value attribute will also appear inside the button on the screen.
HTML Code: <input type="submit" value="Go!" />
If you use an image as a button, use the alt attribute to match the text in the image or to describe what the button does.
HTML Code: <input type="image" src="go_button.jpg" alt="Go!" />
On the web, it is common to indicate required form fields by color or bold text. However, neither of these is enough by itself. Not all screen readers distinguish bold text, and color alone is no help to a screen reader user or to a color-blind user. The most common solution is to include an asterisk as part of the label. But, some screen readers may not speak the * depending on the user setting.
If a form is to be validated, an error message should be displayed in an accessible manner (not in red alone) indicating precisely which form controls need to be corrected or completed:
The tabindex
attribute arranges the tab order of elements on a web page. When a user presses the tab key, the cursor will move in the order you define. It was most often recommended with the use of form elements.
Initially, it was thought that tab indexing would be helpful to users by allowing them to skip to elements on a page that the page author deemed important to the user. However, in practice, tab indexes have been inconsistently applied and tended to create confusion by taking the user out of the normal flow of the document text. In essence, this creates an alternate "navigation" scheme on a page that presumably already has layout and navigation applied. This can be confusing to a user.
Web sites on which proper accessibility techniques have been implemented do not require the use of the tabindex attribute.
The accesskey
attribute allows your users jump directly to an element on which the accesskey attribute is specified. This technique was often used on form elements to help a user jump between elements. However, the accesskey attribute is no longer considered useful in this context for several reasons:
The accesskey attribute shouldn't be needed on a web site that uses proper accessibility techniques such as headings, lists, skip links, and proper navigation.
If it looks like access key attributes are needed, then you should examine the larger of issue of why they are needed and consider modifying the page using proper accessibility techniques to eliminate this need.