On this page
Tooltip alternatives
Overview
Tooltips are often used to convey information. However, tooltips are rarely appropriate, and its misuse can result in a myriad of accessibility issues. Always consider not using a tooltip for an improved user experience.
Why?
- Tooltips are hidden by default making it easy to miss, so they should never be used to convey critical information.
- Tooltips are never accessible on mobile devices.
- Tooltips should never be set on non-interactive elements (for example,
div
,span
,p
), and should only ever be set on interactive elements (for example,button
,a
). Tooltips on non-interactive elements are not accessible to keyboard users and screen reader users.
Guidelines
For designers
- Reserve tooltips for components like icon buttons.
- Keep your tooltip text minimal.
- Only include tooltips on other components as a last resort.
- Never include tooltips on non-interactive components (
div
,span
,p
).
data:image/s3,"s3://crabby-images/fd5bb/fd5bbd73f344b4107cbb9b52a0b9b38069e5d7c5" alt="Icon buttons with tooltips for edit, favorite, and sponsor"
Use a tooltip to give a text label to an icon button
data:image/s3,"s3://crabby-images/0279c/0279c14d9a95e2b5caccd887e2c02361f2dcff52" alt="Non-interactive text element activating a long and wordy tooltip on hover"
Don't use tooltips on non-interactive elements
Annotations
If you have an appropriate tooltip in your design, annotate the tooltip carefully with the preferred type (whether it's a label or description) to ensure proper semantics.data:image/s3,"s3://crabby-images/2fe3a/2fe3a012f1a28135efe579776718d5707bc8017c" alt="Mock of an icon button and its tooltip with an annotation pointing to the tooltip with 'label' text"
For developers
If you come across a design or a page with a tooltip on a static element (for example, div
, span
, p
), remove it. Consult a designer for an alternative way of conveying the information.
If you determine that tooltips are appropriate for your use case, make sure to carefully follow guidelines set in Primer ViewComponents: Tooltip component.
Alternatives to tooltips
1. Persist the content
If possible, persist the content so it's always available rather than using a tooltip, which hides content by default. This ensures that the content is always discovered and surfaced to users regardless of device.
data:image/s3,"s3://crabby-images/78d91/78d91de0c5a30c164e07bb37c7ef12716be985bb" alt="Information about how many discussions can be pinned added to the confirmation dialog"
Find an appropriate permanent place to display additional information.
data:image/s3,"s3://crabby-images/af275/af27547cf458ef26b95d88237cd45b7bd1d1bbbc" alt="Information about how many discussions can be pinned within tooltip on non-interactive element"
Don't use a tooltip to add additional helpful information
2. Don't duplicate content
If the tooltip duplicates content that is already available on the page, remove it.
data:image/s3,"s3://crabby-images/62ef9/62ef9c5323616ae9325134bc3301270cc10c5c0f" alt="Pointer hovering over a link with no tooltip"
Remove any duplicate tooltip text.
data:image/s3,"s3://crabby-images/96aae/96aae83eaf2da52e6c6bf0b29565c0dc815f24cc" alt="Screenshot of tooltip with GitHub username, @inkblotty, on a static span that says @inkblotty"
Don't set tooltips that duplicate the trigger element content.
3. Use a modal
Consider using a modal, which is accessible for mobile users and allows you to structure content that may otherwise be crammed into a tooltip.
data:image/s3,"s3://crabby-images/f997f/f997f4000490dc0161dd37172b34cde4e80de9dd" alt="Screenshot of GitHub Actions page with a modal that conveys workflow file information about a runner"
Do use a pattern that is accessible to a larger number of users such as a modal
data:image/s3,"s3://crabby-images/5dbc8/5dbc82b41e8e560b3553e2e254e0c9a254bb511d" alt="Screenshot of GitHub Actions page using a tooltip on a static element to convey long workflow file information"
Don't place long content inside a tooltip
4. Use a summary disclosure
Consider using a summary disclosure that is accessible for mobile users and also offers the ability to show or hide content.
data:image/s3,"s3://crabby-images/cb7f5/cb7f56df16189288982205d4f17fcc596106b86a" alt="Screenshot of GitHub pricing page that uses a summary disclosure to hide and show additional information on each point"
Do use a pattern that is accessible to a larger number of users such as a summary disclosure
data:image/s3,"s3://crabby-images/6903a/6903af0dd7c81ddb91d5bee4637ee0f16b253c09" alt="Screenshot of GitHub pricing page using a tooltip to hide and show long descriptions on each point"
Don't use tooltips on non-interactive elements
Other
If you are unsure which alternative is more suited to your scenario and need help, consult a designer or the GitHub Accessibility team (if you are GitHub staff) for advice.