The HTML aria-labelledby attribute
The aria-labelledby attribute gives an element an accessible name by pointing to the id of one or more other elements, whose text is concatenated in order. Value: a space-separated list of element ids.
Overview
The aria-labelledby attribute names an element by referencing the id of one or more other elements.
It is one of ARIA's naming and description properties, which give an element an accessible name or description for assistive technology. Whenever you can, associate visible text — a <label>, or aria-labelledby pointing at on-screen text — so sighted and screen-reader users get the same information, rather than hiding it in an invisible string.
Like all ARIA, aria-labelledby changes only the accessibility tree — what assistive technology perceives — never the element's behavior or appearance. The first rule of ARIA applies: if a native HTML element or attribute conveys this, use that instead, and only reach for ARIA when nothing native fits.
Syntax
<h2 id="billing">Billing</h2>
<section aria-labelledby="billing"> … </section>
Values
| Value |
|---|
| A space-separated list of element id values. |
Example
<h2 id="sec-title">Account settings</h2>
<section aria-labelledby="sec-title">
…
</section>
Best practices
- Follow the first rule of ARIA — use a native HTML element or attribute that conveys this where one exists, rather than adding ARIA.
- Prefer referencing visible text (a <label> or aria-labelledby) over an invisible string where possible.
- Use aria-label only when there is no suitable on-screen text to reference.
- Keep the name concise and meaningful — it is exactly what a screen reader announces.