From 7db371b6861e9492d343551b100f094cc28aae8e Mon Sep 17 00:00:00 2001 From: Ignatius Bagus Date: Fri, 3 Nov 2023 16:44:36 +0700 Subject: [PATCH] fix: prefer `aria-label` over `title` (#47) --- .../aria-label-vs-title-attribute/+article.md | 47 ++++++++++++++++++- 1 file changed, 45 insertions(+), 2 deletions(-) diff --git a/sites/dev.mauss/posts/aria-label-vs-title-attribute/+article.md b/sites/dev.mauss/posts/aria-label-vs-title-attribute/+article.md index ef59428..3e53502 100644 --- a/sites/dev.mauss/posts/aria-label-vs-title-attribute/+article.md +++ b/sites/dev.mauss/posts/aria-label-vs-title-attribute/+article.md @@ -1,5 +1,5 @@ --- -date: "2020-09-26T17:38:25+07:00" +date: "2023-11-03T18:00:00+07:00" title: Accessibility! aria-label vs. title attribute description: What's the difference and which one should you choose between these two. tags: [accessibility, html] @@ -9,7 +9,50 @@ The title attribute is read by screen readers, but so does aria-label. They seem Title allows you to add a native tooltip on hover, so if you're not planning to make you own tooltip but needs or wants your element to have one, then add a title attribute. On the other hand, aria labels are supported by default and are used by screen readers. It's not to say that title isn't read by screen readers, but aria is the preferred choice for accessibility support. -The answer is to simply use both `aria-label` and `title` attribute if you need the tooltip, otherwise `aria-label` is the preferred choice for accessibility support, especially if your elements doesn't have any text content, like a linked icon for example. +My recommendation is to use `aria-label` and roll your own tooltip based on the contents of the label using CSS attribute selectors and pseudo-elements. It will be better than relying on the `title` tooltip from browsers that cannot be styled or doesn't zoom with the rest of the elements in some cases. For more complex stuff, you may need to implement a custom one based on your needs and specifications. + +```css +/* arrow pointing to the element */ +[aria-label]::before { + content: ''; + opacity: 0; + pointer-events: none; + position: absolute; + + /* customize this yourself */ + bottom: -0.2rem; + left: 2.5rem; + border-right: 0.5rem solid transparent; + border-bottom: 0.5rem solid rgb(48, 64, 81); + border-left: 0.5rem solid transparent; + transition: opacity 0.2s; +} +/* tooltip text container */ +[aria-label]::after { + content: attr(aria-label); + z-index: 1; + opacity: 0; + pointer-events: none; + position: absolute; + + /* customize this yourself */ + bottom: 0; + left: 0; + display: flex; + padding: 0.25rem 0.375rem; + border-radius: 0.25rem; + transition: opacity 0.2s; + transform: translateY(100%); + background-color: rgb(48, 64, 81); + color: white; +} +/* only show the tooltip on hover */ +[aria-label]:hover::after, +[aria-label]:hover::before { + opacity: 1; + pointer-events: auto; +} +``` *** Reference(s):