EA-R13
Empty Link
This rule is an error and tests the following accessibility guidelines:
Description
This rule checks that each link has a non-empty accessible name.
Explanation
This link has no content and no target (href-attribute).
Applicability
This rule applies to any HTML element that is an inheriting semantic link
included in the accessibility tree.
Expectation
Each target element has an accessible name that is not empty (""
).
Assumptions
The rule assumes that all links are user interface components as defined by WCAG 2. When the link role is used on elements that do not behave as links, failing this rule might not mean that the success criteria are failed.
Accessibility Support
- There are assistive technologies that do not support using the
title
attribute for an accessible name, or in which this feature can be disabled. - For
area
elements that have anhref
attribute, but are not nested inside amap
element, there are differences between browsers and assistive technology on if thearea
is included in the accessibility tree. - Implementation of Presentational Roles Conflict Resolution varies from one browser or assistive technology to another. Depending on this, some semantic
link
elements can fail this rule with some technology but users of other technologies would not experience any accessibility issue. - Accessibility support for some elements inheriting the semantic role of
link
(e.g. elements withdoc-*
attributes) may vary depending on the assistive technology in use.
Background
Related Rules
Bibliography
- Understanding Success Criterion 2.4.4: Link Purpose (In Context)
- ARIA7: Using aria-labelledby for link purpose
- ARIA8: Using aria-label for link purpose
- Understanding Success Criterion 4.1.2: Name, Role, Value
- F89: Failure of Success Criteria 2.4.4, 2.4.9 and 4.1.2 due to not providing an accessible name for an image which is the only content in a link
Tip
Remove empty links.
Examples
Passed
Example 1 - Passed
This a
element has an accessible name from its content.
<a href="https://www.w3.org/WAI"> Web Accessibility Initiative (WAI) </a>
Example 2 - Passed
This div
element has an explicit semantic role of link
and an accessible name from its content.
<div role="link" onclick="openLink(event)" onkeyup="openLink(event)" tabindex="0">
Web Accessibility Initiative (WAI)
</div>
<script>
function openLink(event) {
if (event.type === 'click' || ['Enter', ' '].includes(event.key)) {
window.location.href = 'https://www.w3.org/WAI/'
}
}
</script>
Example 3 - Passed
This button
element has an explicit semantic role of link
and an accessible name from its content.
<button role="link" onclick="window.location.href='https://www.w3.org/WAI/'">Click me for WAI!</button>
Example 4 - Passed
This a
element has an accessible name via aria-label
<a href="https://www.w3.org/WAI"
><img src="/test-assets/shared/w3c-logo.png" aria-label="Web Accessibility Initiative"
/></a>
Example 5 - Passed
This a
element has an accessible name via title
.
<a href="https://www.w3.org/WAI" title="Web Accessibility Initiative"
><img src="/test-assets/shared/w3c-logo.png" alt=""
/></a>
Failed
Example 1 - Failed
This a
element has an empty accessible name.
<a href="http://www.w3.org/WAI"></a>
Example 2 - Failed
This a
element with an image has an empty accessible name. The image is decorative and is marked as such with an empty alt
attribute value.
<a href="https://www.w3.org/WAI"><img src="/test-assets/shared/w3c-logo.png" alt=""/></a>
Example 3 - Failed
This a
element with an image has an empty accessible name. The image is decorative because it has a role
attribute value of presentation
.
<a href="http://www.w3.org/WAI"><img src="/test-assets/shared/w3c-logo.png" role="presentation"/></a>
Example 4 - Failed
This a
element with an image has an empty accessible name. The image is decorative because it has a role
attribute value of none
.
<a href="http://www.w3.org/WAI"><img src="/test-assets/shared/w3c-logo.png" role="none"/></a>
Example 5 - Failed
This a
element with an img
with an empty title
has an empty accessible name.
<a href="https://www.w3.org/WAI"><img src="/test-assets/shared/w3c-logo.png" title=""/></a>
Inapplicable
Example 1 - Inapplicable
This a
element does not have a semantic role of link
because it has been changed to button
.
<a href="https://www.w3.org/WAI" role="button">
Web Accessibility Initiative (WAI)
</a>
Example 2 - Inapplicable
This a
element is not included in the accessibility tree due to display: none
.
<a href="https://www.w3.org/WAI" style="display: none;"><img src="/test-assets/shared/w3c-logo.png"/></a>
Example 3 - Inapplicable
This a
element is not included in the accessibility tree due to visibility: hidden
.
<a href="https://www.w3.org/WAI" style="visibility: hidden;">Some text</a>
Acknowledgments
This document includes material copied from or derived from https://www.w3.org/WAI/standards-guidelines/act/rules//. Copyright © 2023 W3C® (MIT, ERCIM, Keio, Beihang).