W3C Working Draft 14-August-1998
Please see the Acknowledgments for a complete list of contributors.
This document provides guidelines to user agent manufacturers (producers of browsers, players, etc.) for making their products more accessible to persons with disabilities. These guidelines are intended to improve Web browsing for able-bodied users as well.
In a later version of this document, developers will find a helpful checklist for identifying and prioritizing accessibility features.
This document is part of a series of accessibility documents published by the Web Accessibility Initiative.
This is a W3C Working Draft for review by W3C members and other interested parties. It is a draft document and may be updated, replaced or obsoleted by other documents at any time. It is inappropriate to use W3C Working Drafts as reference material or to cite them as other than "work in progress". This is work in progress and does not imply endorsement by, or the consensus of, either W3C or members of the WAI User Agent (UA) working group.
This document has been produced as part of the W3C WAI Activity, and is intended as a draft of a Proposed Recommendation for how to improve user agent accessibility. The goals of the WAI-UA Working Group are discussed in the WAI UA charter. A list of the current Working Group members is available.
This document is available in the following formats:
In case of a discrepancy between the various formats of the specification, http://www.w3.org/WAI/UA/WD-WAI-USERAGENT-19980814 is considered the definitive version.
Please send comments about this document to the public mailing list: w3c-wai-ua@w3.org.
Each guideline is classified according to the following rating system:
The guidelines in this document have been organized around the following general principles of accessible browser design:
This document does not specify how browsers should implement the guidelines listed herein (although in some instances, sample implementation strategies are indicated). The guidelines do depend, however, on the following document and user agent characteristics.
A document is a series of elements that are defined by a language (e.g., HTML 4.0 or an XML application). Each element consists of a name that identifies the type of element, optional attributes that take values, and (possibly empty) content. Some attributes are integral to document accessibility (e.g., the "alt", "title", and "longdesc" attributes in HTML).
The rendered content is that which an element actually causes to be rendered by the user agent. This may differ from the element's structural content. For example, some elements cause external data to be rendered (e.g., the IMG element in HTML), and in some cases, browsers may render the value of an attribute (e.g., "alt", "title") in place of the element's content.
The presentation of a document is described by properties (e.g., font face, font sizes for different headers, paragraph justification, text color, etc.).
Each property has a current value at any moment (e.g., "Helvetica" for font face, "12 point" for font size, "black" for text color, etc.) The current value comes from one of the following sources: browser, document, or user.
The value given to a property when the browser is first "turned on" is called the default value. Browsers may allow users to change default values through a variety of mechanisms (e.g., the user interface, style sheets, initialization files, etc.). Setting the current value of a property does not change the default value.
A property may receive its current value when the user agent reads a document: through style sheets within the document or linked externally, through the presentation attributes of an element, via a server, etc. These values are called author styles.
Finally, the user may set the current value through user style sheets or the user interface; these are called user styles.
Browsers allow users to interact with the rendered document through several mechanisms.
A browser may offer several views of the same document. For instance, one view may show a table of contents and a second the actual contents. A user accesses the information in a view through a window, frame, or other viewport. The size of the viewport may prevent the user from accessing all of the information in the view at once; viewports may offer scrolling mechanisms to give access to all of the view's information.
A selection is a set of elements identified for a particular operation. The user selection identifies a set of elements for certain types of user interaction (e.g., cut, copy, and paste operations). The user selection may be established by the user (e.g., by a pointing device or the keyboard) or via an accessibility API. A view may have several selections, but only one user selection. When several views co-exist, each may have a user selection, but only one is active, called the current user selection.
Selections may be rendered specially (e.g., visually highlighted). Highlighted text is often used by third-party assistive technologies to indicate through speech or Braille output what the user wants read. Most screen readers are sensitive to highlight colors. Third-party assistive technologies may provide alternative presentation of the selection through speech, enlargement, or dynamic Braille display.
The focus designates the element (link, form control, element with associated scripts) in a view that will react when the user next interacts with the document. The user is said to activate the element with the focus. For instance, a user may activate a link (which usually causes the user agent to follow the link), a form control (which usually causes a change of state in the form control), or an element with associated scripts. A view has only one focus. When several views co-exist, each may have a focus, but only one is active, called the current focus.
Both the current focus and the current user selection must be in the same view, called the current view.
Events, which may occur to a document or part of a document, cause the browser to behave in a certain way. For instance, an event occurs when a document is loaded into the browser or unloaded, when a mouse button is depressed or released (when released, the browser performs the action specified by the button), when a link is activated (it is generally followed), etc. Events may occur with or without user action, especially with documents using "Dynamic HTML" (DHTML) and scripting programs.
Certain types of content may not be accessible to all users (e.g., images), so user agents must ensure that alternate textual representations ("Alt-text") of information be available to the user. Alternate text can come from element content (e.g., the OBJECT element) or attributes (e.g., "alt" or "title"). When not supplied by the author, the user agent should generate alternate text. Approaches in such cases may vary. For instance, the user agent may simply substitute the word "IMAGE" or "APPLET" for the object in question. More sophisticated solutions in the case of an image that is content of a link might involve following the link and retrieving the title of the target document.
A description link, or D-Link, is an author-supplied link to additional information about a piece of content that might otherwise be difficult to access (image, applet, video, etc.). The "WAI Accessibility Guidelines: Page Authoring" document (see [WAI-PAGEAUTH]) describes when and how to insert description links in a document.
D-links should be identified in the document source by giving the "rel" attribute the value "dlink".
This document distinguishes two types of user agents as they relate to accessibility and calls them dependent and independent user agents.
A dependent user agent relies on the rendering of another user agent to perform its tasks. Dependent user agents include screen magnifiers and screen readers, both of which rely on the visual output of another user agent.
An independent user agent only requires the source document (and associated style sheets, etc.) to perform its tasks. It may use an accessibility API to retrieve information about a document.
Note. Future versions of this document may make clearer distinctions about which guidelines are meant for which type of user agent.
Users should be allowed to select whether they want the user agent to render the principal content (e.g., an image or applet), alternative representations (e.g., a long description), or both.
Users should also be allowed to specify where the information should be rendered: inline or in a separate view. For instance, users with low vision may want to look at an image, but may require that the image be rendered in a separate view. Or, users may require that a long description be rendered inline (as a D-link or in a separate view).
Similarly, users with certain disabilities may want both embedded applications and descriptive text information to be rendered simultaneously.
In the case of the IMG element (see [HTML40]), there are two potential sources of short descriptive text (in order of preference): the "alt" and "title" attributes. The latter may be used as a "tool tip" (information displayed when the user hovers over an element with a pointing device).
In the case of the OBJECT element, the text content of the OBJECT is considered its alternative text (see [HTML40], section 13.3.1 for complete rules about rendering OBJECT elements, embedded OBJECT elements, etc.). If the element has no content, the value of the "title" attribute should be used.
The entire descriptive text should be rendered, whatever its source or the dimensions specified for the original image. Rendered text should be wrapped so the user doesn't need to scroll horizontally to read the description.
If the author has not supplied alternative content with an element, the browser may render the word "Image".
In the case of the OBJECT element, the text content of the OBJECT is considered its alternative text (see [HTML40], section 13.3.1 for complete rules about rendering OBJECT elements, embedded OBJECT elements, etc.). If the element has no content, the value of the "title" attribute should be used.
In the case of the APPLET element, the element's text content, the value of its "alt" attribute, or the value of its "title" attribute (in order of preference) should be used. Note. The APPLET element is deprecated in HTML 4.0 (see [HTML40]) and authors should use the OBJECT element instead.
For either element, the entire descriptive text should be rendered, whatever its source or the dimensions specified for the original image. Rendered text should be wrapped so the user doesn't need to scroll horizontally to read the description.
If the author has not supplied alternative content the browser may display the word "Applet" or "Object".
If an element specifying an application could not be loaded, the browser should provide the user with an explanation (e.g., missing object, server not ready, etc.).
Note. If applets written in Java have been designed for accessibility (see Sun Microsystems Java Accessibility in the Appendix), the user agent should provide that access.
The following is an example of sample markup for a table without TH information:
<TABLE>
<CAPTION>A table without any HD tags</CAPTION>
<TR>
<TD>AAAAA AA AAAA AAA AAAA AA A AAAAA AAAA AAAAA</TD>
<TD>BB BBBB BB BBBB BBBBBB B BBB BB BBBBB BBBB BBB</TD>
<TD>C CCCC CC CCCCC CC CCCC CCCC CCCCCC CCCCC CCC</TD>
</TR>
<TR>
<TD>DDD DD DDDD DD DDDD DDD DDDDD DDD DD DDDD D DDDD</TD>
<TD>E EE EEEE EE EEEE E EEEEE EE EEEEE EE EEE EEEE EE</TD>
<TD>FFFF FF FFFF FFF FFF FFF FF FFF FFFFF FFFF FFFF </TD>
</TR>
</TABLE>
A serialization based on row order would be rendered as:
A table without any HD tags
AAAAA AA AAAA AAA AAAA
AA A AAAAA AAAA AAAAA
BB BBBB BB BBBB BBBBBB
B BBB BB BBBBB BBBB BBB
C CCCC CC CCCCC CC CCCC
CCCC CCCCCC CCCCC CCC
DDD DD DDDD DD DDDD DDD
DDDDD DDD DD DDDD D DDDD
E EE EEEE EE EEEE E EEEEE
EE EEEEE EE EEE EEEE EE
FFFF FF FFFF FFF FFF FFF
FF FFF FFFFF FFFF FFFF
A serialization based on column order would be rendered as:
A table without any HD tags
AAAAA AA AAAA AAA AAAA
AA A AAAAA AAAA AAAAA
DDD DD DDDD DD DDDD DDD
DDDDD DDD DD DDDD D DDDD
E EE EEEE EE EEEE E EEEEE
EE EEEEE EE EEE EEEE EE
BB BBBB BB BBBB BBBBBB
B BBB BB BBBBB BBBB BBB
C CCCC CC CCCCC CC CCCC
CCCC CCCCCC CCCCC CCC
FFFF FF FFFF FFF FFF FFF
FF FFF FFFFF FFFF FFFF
Tabular information can confuse users with certain dependent user agents. User agents should be able to serialize the table -- render it one cell at a time -- to reduce confusion.
Users should be able to specify whether they want the cells rendered row order or column order.
Users may choose different mechanisms for rendering cell header information (e.g., render row and column header information before each cell, render row header information once at the beginning of the row, etc.) The HTML 4.0 specification (see [HTML40], chapter 11 and in particular section 11.4.3) and the CSS 2 specification (see [CSS2], chapters 12, 17, and 19) describe mechanisms for structuring tables, identifying headers, and rendering them in accessible ways.
See also the section on table navigation for related information.
Note. Table serialization is important for tables used to structure tabular information as well as those used to lay out blocks of information.
The following is an example of sample markup for a table without TH information:
<TABLE>
<CAPTION>A 3x3 data table signified by the use of HD tags</CAPTION>
<TR>
<TH></TH>
<TH>AAA</TH>
<TH>BBB</TH>
<TH>CCC</TH>
</TR>
<TR>
<TH>DDD</TH>
<TD>Data 11</TD>
<TD>Data 12</TD>
<TD>Data 13</TD>
</TR>
<TR>
<TR>
<TH>EEE</TH>
<TD>Data 21</TD>
<TD>Data 22</TD>
<TD>Data 23</TD>
</TR>
<TR>
<TR>
<TH>FFF</TH>
<TD>Data 31</TD>
<TD>Data 32</TD>
<TD>Data 33</TD>
</TR>
</TABLE>
A serialization based on row order would be rendered as:
A 3x3 data table signified by the use of HD tags
Row: DDD Column: AAA
Data11
Row: DDD Column: BBB
Data12
Row: DDD Column: CCC
Data13
Row: EEE Column: AAA
Data21
Row: EEE Column: BBB
Data22
Row: EEE Column: CCC
Data23
Row: FFF Column: AAA
Data31
Row: FFF Column: BBB
Data32
Row: FFF Column: CCC
Data33
A serialization based on column order would be rendered as:
A 3x3 data table signified by the use of HD tags
Column: AAA Row: DDD
Data11
Column: AAA Row: EEE
Data21
Column: AAA Row: FFF
Data31
Column: BBB Row: DDD
Data12
Column: BBB Row: EEE
Data22
Column: BBB Row: FFF
Data32
Column: CCC Row: DDD
Data13
Column: CCC Row: EEE
Data23
Column: CCC Row: FFF
Data33
Tabular information can confuse users with certain dependent user agents. User agents should be able to serialize the table -- render it one cell at a time -- to reduce confusion.
Users should be able to specify whether they want the cells rendered row order or column order.
Users may choose different mechanisms for rendering cell header information (e.g., render row and column header information before each cell, render row header information once at the beginning of the row, etc.) The HTML 4.0 specification (see [HTML40], chapter 11 and in particular section 11.4.3) and the CSS 2 specification (see [CSS2], chapters 12, 17, and 19) describe mechanisms for structuring tables, identifying headers, and rendering them in accessible ways.
See also the section on table navigation for related information.
Note. Table serialization is important for tables used to structure tabular information as well as those used to lay out blocks of information.
If the browser provides more than one view, the user should be able to toggle between alternative views of the document. Selections between views should be synchronized.
This is particularly important for third-party assistive technologies (see the section on compatibility for more information.)
Note. At the writing of this document, there is no general and standard mechanism for associating style with events. CSS may be used, however, for certain events (namely hover, focus, and link activation).
To navigate a document may involve displaying different parts of it (e.g., by scrolling) or shifting focus to different elements. One of the key issues related to navigation and control is the ability to use the keyboard to access all links, form controls and DHTML events. This includes the emulation of DHTML-based mouse events.
The user should be able to use keyboard or pointing input commands to navigate, expand, or contract the hierarchy. The hierarchy is defined by block level HTML elements like H1-H6, OL, UL, TABLE, MENU, DIV and etc.. For example a view could start by just showing H1 level headers. If the user selects the first H1 header the user agent would expose the headers and other block level items between the first H1 and the next H1.
The user should be able to navigate specifically those elements related as parents/children. The user should also be able to navigate specifically those elements related as siblings.
The focus should be highlighted within the hierarchy in a way that is compatible with third-party assistive technology (see the section on compatibility).
A table navigation mechanism should also provide the user with information about the current table cell (see the guidelines on alternative representations of tables).
For example, if a browser has a menu item labeled "Headers", that menu should allow navigation among header elements. The display of the "Headers" menu could read "N Headers" where "N" is the number of headers in the current document. The sub-menu items might include "Next Header", "Previous Header", "All Headers", and a dynamically created list of the first 10 headers in the document.
Obviously, the tool used to consult on-line documentation should be accessible to users with disabilities.
The following guidelines apply to user agents that implement Cascading Style Sheets (see CSS, level 1 and CSS, level 2). Cascading Style Sheets may be part of a source document or linked externally.
Stand-alone style sheets are useful for implementing user profiles in public access computer environments where several people use the same computer. User profiles allow for convenient customization and may be shared by a group.
Overlapping rules from author, user, and browser style sheets cascade (i.e., combine) to produce a single rule that assigns a current value to a property.
The following appendix is informative only.
Many major operating systems have built-in accessibility features for improving the usability of the standard operating system by persons with disabilities. When designing an application program, developers should test to see if their product is compatible with the features in the target operating system. This should not be a problem if developers use standard development tools and standard software design practices.
The accessibility options can be adjusted from the control panel.
The accessibility options can be adjusted from the control panels through the Easy Access option and the Closeview option.
Disability access server features, known as AccessX, provide basic workstation accessibility, typically used by people with mobility impairments. AccessX became a supported part of the X Windows server in version X11/R6. The built-in server level access features include:
The following appendix is informative only.
The following is a list of currently public accessibility APIs that are available for various operating systems. The inclusion of this list is not an endorsement of any particular accessibility API by the W3C in general or WAI in particular. The information is provided only as a convenience to browser developers.
The WAI Working Group strongly recommends using accessibility APIs to promote compatibility with 3rd party assistive technology. Third-party assistive technology can use the accessibility information provided by the APIs to provide an alternative user interface for various disabilities.
Information on active accessibility can be found at the Microsoft WWW site on Active Accessibility.
Information on Java Accessibility API can be found at Java Accessibility Utilities.
The following appendix is informative only.
In addition, we would like to thank the following people who have contributed through review and comment: Paul Adelson, James Allen, Denis Anson, Kitch Barnicle, Harvey Bingham, Kevin Carey, Wendy Chisholm, Chetz Colwell, Neal Ewers, Geoff Freed, Larry Goldberg, Markku Hakkinen, Chris Hasser, Kathy Hewitt, Phill Jenkins, Leonard Kasday, George Kerscher, Marja-Riitta Koivunen, Josh Krieger, Greg Lowney, Scott Luebking, William Loughborough, Napoleon Maou, Charles McCathieNevile, Masafumi Nakane, Charles Opperman, Mike Paciello, David Pawson, Helen Petrie, David Poehlman, Michael Pieper, Jan Richards, Greg Rosmaita, Liam Quinn, T.V. Raman, Robert Savellis, Constantine Stephanidis, Jim Thatcher, Jutta Treviranus, Claus Thøgersen, Steve Tyler, Gregg Vanderheiden, Jaap van Lelieveld, Jon S. von Tetzchner, Ben Weiss, Evan Wies, Chris Wilson, Henk Wittingen, and Tom Wlodkowski.
If you have contributed to the UA guidelines and your name does not appear please contact the editors to add your name to the list.