and [images](#images-with-accessible-names) have descriptive accessible names.
- Icons
-[Non-decorative icons](#icons-that-convey-information) have an `aria-label`.
-[Clickable icons](#icons-that-are-clickable) are buttons, that is, `<gl-button icon="close" />` is used and not `<gl-icon />`.
- Icon-only buttons have an `aria-label`.
- Interactive elements can be [accessed with the Tab key](#support-keyboard-only-use) and have a visible focus state.
- Are any `role`, `tabindex` or `aria-*` attributes unnecessary?
- Can any `div` or `span` elements be replaced with a more semantic [HTML element](https://developer.mozilla.org/en-US/docs/Web/HTML/Element) like `p`, `button`, or `time`?
## Provide accessible names for screen readers
To provide markup with accessible names, ensure every:
To provide markup with accessible names, ensure every:
-`input` has an associated `label`.
-`input` has an associated `label`.
-`button` and `a` have child text, or `aria-label` when text isn't present.
-`button` and `a` have child text, or `aria-label` when child text isn't present, such as for an icon button with no content.
For example, an icon button with no visible text.
-`img` has an `alt` attribute.
-`img` has an `alt` attribute.
-`fieldset` has `legend` as its first child.
-`fieldset` has `legend` as its first child.
-`figure` has `figcaption` as its first child.
-`figure` has `figcaption` as its first child.
-`table` has `caption` as its first child.
-`table` has `caption` as its first child.
Groups of checkboxes and radio inputs should be grouped together in a `fieldset` with a `legend`.
`legend` gives the group of checkboxes and radio inputs a label.
If the `label`, child text, or child element is not visually desired,
If the `label`, child text, or child element is not visually desired,
use `.gl-sr-only` to hide the element from everything but screen readers.
use `.gl-sr-only` to hide the element from everything but screen readers.
Ensure the accessible name is descriptive enough to be understood in isolation.
### Examples of providing accessible names
The following subsections contain examples of markup that render HTML elements with accessible names.
Note that [when using `GlFormGroup`](https://bootstrap-vue.org/docs/components/form-group#accessibility):
- Passing only a `label` prop renders a `fieldset` with a `legend` containing the `label` value.
- Passing both a `label` and a `label-for` prop renders a `label` that points to the form input with the same `label-for` ID.
#### Text inputs with accessible names
When using `GlFormGroup`, the `label` prop alone does not give the input an accessible name.
The `label-for` prop must also be provided to give the input an accessible name.