Overview
Before we dive into the rules of the ARIA, let me reiterate what ARIA is going to do. ARIA stands for accessible rich internet applications and it defines the way to make the web content or web applications more accessible to people with the disabilities.
Even though ARIA has evolved couple of years ago, still some of the developers misuse the usage of the ARIA due to the lack of thorough knowledge . Misusing of the ARIA results much more damage to the web page in terms of it’s accessibility. That is the reason there is saying “No ARIA is better than bad ARIA!“. Having said that, if developers understand and follow the rules of the ARIA then definitely it is going to help to certain extent in avoiding some of the mistakes. Let us understand what are those rules of the ARIA in details.
Rules of the ARIA
Rule1: don’t use ARIA, use native HTML instead
The first rule talks about use native HTML elements or attributes to convey the semantics to the people with the disabilities. In the case, the semantics that you are looking for is not available in the HTML then use ARIA. Let me explain this with the example. To construct the checkbox on a web page, use HTML checkbox(<input type=”checkbox”>) but do not use ARIA checkbox(<div role=”checkbox”>…</div>). The reason is that HTML checkbox conveys the semantics to the people with disabilities without any additional effort as it is already mapped to the accessibility APIs. Now the question is when to use ARIA. There are some scenarios where we might have to use ARIA and they are:
- When the website is not designed from the scratch and is being retrofit for an accessibility then it is better to use ARIA in order to save time, effort, and money
- If it is not possible to style the native element as per need for some reason(exceptional cases) then it is ok to construct the custom element and style as per the need and provide the semantics to the element by using ARIA
- If the required semantics are not present in the host language(HTML 5.x) then use ARIA to communicate the semantics. For the instance, one needs to use ARIA to convey the tree semantics as there is no such equivalent HTML element or attribute.
- When the user agent support of some of the HTML 5.x is not great then use ARIA without any second thought.
Rule2: Do not change native semantics, unless you really have to.
As discussed earlier, most of the HTML elements or attributes convey one or other semantics. We are not supposed to change the native semantics unless it is really essential. For example: Developer wants to build a heading that is a tab
Do not do this:
<h2 role=tab>heading tab</h2>
Do this:
<div role=tab><h2>heading tab</h2></div>
Rule3: All interactive ARIA controls must be usable with the keyboard.
Providing the ARIA roles would bring the semantics to the custom control but it would never bring control to work as expected with the keyboard. We need to remember that ARIA is nothing to do with the keyboard functionality and is just to provide the semantics to the accessibility APIs. Being said, it is developer responsibility to make the custom control accessible with the keyboard by using some scripting. For example, if we construct the custom button(<div role=”button”>) then we need to make sure that it receives the focus and user is able to activate the associated functionality by using both enter and space keys. To put it simpler, custom button should work with the keyboard as how native button works.
Rule4: Do not use role=”presentation” or aria-hidden=”true” on a focusable element
Role=”presentation” or role=”none” is to negate eh semantics from the accessibility tree and the element that has role= “none” is not supposed to be an interactive in any way. On the similar lines, Aria-hidden attribute is to hide the content or element from the accessibility APIs and the element that has aria-hidden set to true is not supposed to be an interactive in any way. Defining either of these attributes on the visible focusable elements results some users focus nothing.
Do not do this:
<button role=presentation>press me</button>
Do not do this either:
<button aria-hidden=”true”>press me</button>
<button aria-hidden=”true”>press me</button>
Do this:
<button role=”presentation” tabindex=”-1″>Don’t Click Me</button>
<button aria-hidden=”true” style=”display: none;”>don’t Click Me</button>
Rule5: All interactive elements must have an accessible name.
All interactive elements(such as links, buttons, text fields, combo boxes, radio buttons, checkboxes and so on..) on a web page must have accessible name. Without accessible name, assistive technologies do not understand what the control is all about. To provide the accessible name, there are techniques available and they vary from control to control. Let us look some of them.
- HTML links and buttons: whatever the link text/button value that we provide, it becomes the accessible name
- Input text fields: in order to provide the
accessible name, form controls need to be associated with it’s visible
label either implicitly or explicitly.
For example: The below input text field has visible label but there is no accessible name
First name<input type=”text”>
The below input text field have both visible label and accessible name. Accessible names establishes with the for and ID connection
<label for=”fname”>First name</label>
<input type=”text” id=”fname”>
- Custom widgets: in order to provide the accessible name for the custom widgets, authors can use either aria-label or aria-labelledby techniques