這系列無障礙的鐵人賽文章,實踐的內容主要是根據 W3C:WAI-ARIA 的實踐,從設計模式及組件(Design Patterns and Widgets)裡面挑選最想嘗試的,如果有朋友想瞭解全部 Widget 該怎麼實作及其規範,歡迎自行爬規範內容,也許我們可以討論一下;若以下文章內容理解有任何錯誤,請多指教~
(圖片來源:codyhouse)
3.4 Breadcrumb
A breadcrumb trail consists of a list of links to the parent pages of the current page in hierarchical order. It helps users find their place within a website or web application. Breadcrumbs are often placed horizontally before a page's main content.
大家應該對「麵包屑」不陌生吧,我們在瀏覽很多網站時,為了要讓身為使用者的我們隨時知道當前的頁面相對於網站結構中的位置,就可以從麵包屑一目瞭然。麵包屑其實就是一組有序的位置提示,這個提示可以是超連結或是純文字,是導覽列的做法之一。
在今天的文章當中,不是要教你怎麼製作麵包屑,而是從 codyhouse 借了個現成的範例(開源的),挑一個我喜歡的麵包屑,將它改成無障礙加強版!它雖不在 WAI-ARIA 的「角色 Role」之一,卻是我們在網站中常常會出現的組件。
breadcrumb
不需要支援鍵盤的操作。aria-label
或 aria-labelledby
為它標上說明。
aria-label
屬性中,填寫的「文字內容」作為麵包屑的標題,在瀏覽器中不可見的,螢幕閱讀器則會朗讀。aria-labelledby
屬性中,填寫的值是某個元素的 id
,某元素的內容一樣會作為麵包屑的標題。aria-current
屬性作為標示,值是 page
,但如果當前所在位置只是「文字」,並非超連結的話,那麼這個屬性是選擇性,看你要不要加上去。今天要提高現成的麵包屑可訪問性!因為發現前兩次的內容,預設情境,寫得很久,也無法讓很多人理解「概念」,這次不管樣式的部分,直接針對 HTML 結構變化,來理解概念吧!
希望能做到:
<nav>
<ol class="cd-breadcrumb custom-separator">
<li><a href="#0">Home</a></li>
<li><a href="#0">Gallery</a></li>
<li><a href="#0">Web</a></li>
<li class="current"><em>Project</em></li>
</ol>
</nav>
<nav>
作為容器,可是沒有做標題 aria-label
的標示。如果你是使用 <div>
,記得要加上 role="navigation"
。aria-current
要加不加隨意,為了練習,還是加一下吧!<!-- 1. 含有 navigation 的角色 -->
<!-- 2. 使用 aria-label 賦予標籤(名稱) -->
<nav aria-label="Breadcrumb">
<ol class="cd-breadcrumb custom-separator">
<li><a href="#0">Home</a></li>
<li><a href="#0">Gallery</a></li>
<li><a href="#0">Web</a></li>
<!-- 3. 使用 aria-current="page" 告知當前所在頁面 -->
<li class="current"><em aria-current="page">Project</em></li>
</ol>
</nav>
<nav>
上的 aria-label
填上「 Breadcrumb
」,它也可以是小寫 breadcrumb,也能使用複數 Breadcrumbs,只要能清楚表明它是麵包屑即可。aria-current="page"
就大功告成了。今天的範例很簡單,原始碼在 Codepen!