ARIA屬性

習題預習

User ask:
給我5題ARIA attributes的中文問題

ChatGPT answer:
  1. 在一個網頁上的對話框內,你可以使用哪一個ARIA屬性來指示當前頁面內正在激活的控制項?
  2. 在一個網頁上的表格中,你可以使用哪一個ARIA屬性來表明表格行的內容是數據還是標題?
  3. 當一個網頁具有多個可視導航菜單時,你可以使用哪一個ARIA屬性來標識不同的菜單,以便更好地區分它們?
  4. 在一個可展開的控件中,你可以使用哪一個ARIA屬性來指示該控件目前的狀態是已展開還是已折疊?
  5. 在一個動態輪播中,你可以使用哪一個ARIA屬性來指示當前正在顯示的輪播內容,以便更好地向用戶傳達輪播信息?

說明知識

User ask:
以中文說明ARIA attributes並舉例

ChatGPT answer:

ARIA是Accessible Rich Internet Applications的縮寫,是一種協助開發者打造無障礙網站的技術。ARIA屬性可讓開發者為HTML元素添加功能,以提供螢幕閱讀器、自動化工具等輔助技術對網站的可訪問性。

以下是幾個ARIA屬性的示例及其用法:

  1. aria-label:定義元素的可讀標籤,以提供更詳細的描述。例如:
<button aria-label="關閉對話框">X</button>
  1. aria-describedby:定義與元素相關的文本說明,以給予更多詳情。例如:
<input type="text" aria-describedby="username-help" />

<p id="username-help">請輸入3到6個字符的用戶名</p>
  1. aria-disabled:表示元素是否啟用。例如:
<button aria-disabled="true">已停用的按鈕</button>
  1. aria-haspopup:定義元素是否具有下拉式選單、彈出式對話框等彈出式選單功能。例如:
<a href="#" aria-haspopup="true">下拉式菜單</a>
  1. aria-checked:表示元素是否被勾選。例如:
<input type="checkbox" aria-checked="true" />
  1. aria-expanded:表示元素是否展開。例如:
<button aria-expanded="false" aria-controls="menu">展開選單</button>

<ul id="menu">
  <li><a href="#">菜單項目一</a></li>
  <li><a href="#">菜單項目二</a></li>
</ul>

以上是幾個常用的ARIA屬性示例,這些屬性能協助開發者使網站更加無障礙。

條列重點

User ask:
以中文條列ARIA attributes的重點

ChatGPT answer:

以下是ARIA屬性的重點:

  1. 角色(attribute-role)屬性:定義了元素在頁面中扮演的角色,如菜單、按鈕、文本框等。

  2. 描述(attribute-description)屬性:提供了元素的額外描述信息,以便於屏幕閱讀器能夠更好的理解該元素的含義。

  3. 標籤(attribute-label)屬性:為元素提供了更容易被理解的標籤,通常用來替代沒有語義的標籤,如checkbox、radio等。

  4. tab-index屬性:定義了元素在頁面中的tab鍵次序,以便於鍵盤導航。

  5. 表示狀態的屬性(attribute-state):主要有三種表示狀態的屬性aria-checked,aria-selected和aria-disabled,用於標記元素的狀態。

  6. 語義組(attribute-set):用於將有關聯性的元素如radiogroup、menu等組合到一個語義組中,以便於屏幕閱讀器能夠更好的理解相互關聯的元素。

  7. 輔助功能的提示信息(attribute-popup):定義了與元素相關的提示信息,如彈出窗口、幫助文本等。這些提示信息可以幫助用戶更好地理解元素的功能和用途。

知識測驗

User ask:
以中文給我5題ARIA attributes的中等難度問題,並在後面列出答案

ChatGPT answer:
  1. 什麼是aria-current屬性?
    答案:aria-current屬性指定元素的當前狀態。它可以用來指示哪些元素是當前選擇的或活動的。

  2. 如何使用aria-describedby屬性?
    答案:aria-describedby屬性可以闡述與元素相關的附加描述。它可以被用來作為輔助技術的提示,也可以用來提供更詳細的元素內容。

  3. 什麼是aria-expanded屬性?
    答案:aria-expanded屬性用於指示具有展開/收起功能的元素的當前狀態。它可以被設置為「true」或「false」,用於指示元素是否打開或關閉。

  4. 如何使用aria-label屬性?
    答案:aria-label屬性用於為元素提供可讀的名稱,通常被用於沒有文本描述的圖像、按鈕和表單控件等元素。這可以幫助輔助技術用戶更好地理解頁面內容。

  5. 什麼是aria-hidden屬性?
    答案:aria-hidden屬性可以用於隱藏屏幕閱讀器不應該讀取的元素。當aria-hidden屬性被設置為「true」時,元素將被隱藏並從輔助技術的焦點序列中移除。