A11ying with Sanna - I would if I could a guide to web accessibility

ARIA properties

ARIA properties define additional semantics not supported in regular HTML. Most ARIA properties are static and will not change once they are set. An example of an ARIA property is <button aria-haspopup="true">. This property extends the standard button to cause a screen reader to announce that the button if activated, will trigger a pop-up.

Aria-describedby

The aria-describedby attribute provides an accessible description for an element. This is similar to the aria-labelledby element in the way that you have an element you set as the description.

Example of aria-describedby usage

<label for="my-field">Field label</label>
<input type="text" id="my-field" aria-describedby="help-text" />
<div id="help-text">This is the help text</div>

Aria-required

With aria-required you can tell assistive technologies that a form field is required. The attribute has no other functionality. This can be used in cases where you don't want HTML validation for some reason, for example, in some JavaScript-based solutions. But if you use HTML validation, there is no need for aria-required, just use the required attribute.

Use ARIA to give an element an accessible name

Always aim to avoid having elements without visual labelling. But in the cases you need to have one, remember to use ARIA to provide an accessible name to it.

Aria-label

The aria-label attribute should be used in cases where a text label is not visible on the screen. Assign it a string that labels the current element. The aria-label will override any other native labelling (for example, the <label> element). A good place you might want to provide an aria-label is when you have a button that is visually represented by an image. In this kind of situation, it's good to pause to think if you want to provide the sighted users also with more information than just the image. You can, for example, use the title attribute.

You shouldn't use aria-label everywhere. For example, you don't need to tell the user that an element is a footer. The footer element should be defined with the <footer> tag.

Example of aria-label usage

Case 1: A button that is visually represented by an image. You should provide an aria-label to assistive technology users.

<button aria-label="Close window"><img src="/path/to/the/image" /></button>

Case 2: You have an input field without a visible label. You should provide the assistive technologies a label. It is always a good practice to provide each input field with a visible label. That way you can ensure that all your users can use the information. At least don't rely on the placeholder to act as a label, because the placeholder is not a label.

<input aria-label="Search content" />

Aria-labelledby

With aria-labelledby you specify an HTML element that has the label for the element. The element you use as the label can be hidden visually (but it rarely should be).

Defining relationships between elements

If the element is inside the parent in the DOM, don't use this type of ARIA. But if you can't infer the relationship from the DOM, use ARIA. Using ARIA will help assistive technologies understand the relationships between the elements.

When you have one element controlling the behaviour of another, choose aria-controls. When an element owns another element, use aria-owns.

Aria-controls

The aria-controls attribute tells the element controls another element. A typical use is when one element controls the behaviour or state of another element. An example use case would be accordions or tabs.

Example of aria-controls usage

<button aria-controls="tabContent">My tab</button><div id="tabContent" role="tabpanel">Content for the tab</div>

Aria-owns

Aria-owns tells the element should be treated as a child of the current element. An element can have one explicit owner.

An example use case would be a dropdown menu, like a pop-up sub-menu. Often the other element has dynamically generated content, like a dialog or a menu.

Example of aria-owns usage

<button id="dropdownButton" aria-haspopup="true" aria-owns="dropdownMenu">Dropdown</button> <div id="dropdownMenu" role="menu">Content for the dropdown menu</div>

Source material