ARIA: region ロール
リージョン (region
) ランドマークロールは、文書内で、著者が重要であると識別した領域を識別するために使用されます。 これは、他のランドマークロールのどれも適切でないときでも、汎用のランドマークを提供することで、人々が容易にナビゲートできるようにするために使用されます。
<div role="region" aria-label="例">
<!-- リージョンのコンテンツ -->
</div>
説明
リージョン (region
) ロールは、ARIA のランドマークロールです。 ランドマークロールは、ウェブページの構成と構造を識別する方法を提供します。 ページのセクションを分類およびラベル付けすることにより、レイアウトを通じて視覚的に伝達される構造情報がプログラム的に表されます。 スクリーンリーダーは、ランドマークロールを使用して、ページの重要なセクションにキーボードナビゲーションを提供します。
リージョン (region
) ロールは、ユーザーがそのセクションに簡単にナビゲートし、ページの要約にリストされることを望むほど重要なコンテンツのセクションのために予約するべきです。 リージョン (region
) ロールはより汎用の用語であり、識別が必要なセクションが、banner
、main
、contentinfo
、complementary
、navigation
などの他のランドマークロールのいずれかによって正確に説明できない場合にのみ使用するべきです。
リージョン (region
) ロールを持つすべての要素には、リージョン内のコンテンツの目的を説明するラベルを含めるべきで、目に見えるヘッダーを参照する aria-labelledby
を伴うのが好ましいです。 目に見える適切なヘッダーがない場合は、aria-label
を使用するべきです。
リージョン (region
) ランドマークロールのコンテンツは、文書のメインコンテンツから分離されている場合にも意味をなすべきです。
<section>
要素を使用すると、アクセス可能な名前が与えられている場合、自動的にセクションがリージョン (region
) ロールを持つことを伝えます。 開発者は、ARIA を使用するよりも正しい意味論の HTML 要素(この場合は <section>
)を常に使用するべきです。
関連する WAI-ARIA のロール、ステート、プロパティ
- aria-labelledby
-
リージョンにラベルを付けるには、この属性を使用します。 多くの場合、
aria-labelledby
属性の値は、セクションのタイトルに使用される要素の ID になります。
キーボードインタラクション
無し
必要な JavaScript 機能
無し
例
<div role="region" aria-labelledby="region-heading">
<h2 id="region-heading">
この見出しの
<code>id</code>
属性は、このリージョンがアクセス可能な名前を持つのに役立ちます
</h2>
<!-- リージョンのコンテンツ -->
</div>
アクセシビリティに関する懸念
控えめに使用してください! ランドマークロールは、文書のより大きな全体的なセクションを識別するために、控えめに使用することを意図しています。 あまりにも多くのランドマークロールを使用すると、スクリーンリーダーで「ノイズ」が発生し、ページ全体のレイアウトを理解することが難しくなります。
他の関連コンテンツセクショニング要素またはランドマークロールが当てはまらない場合にのみ、リージョン (region
) ロールを使用してください。 ページ上に複数のリージョンが存在する場合は、そのページの全体構造を再検討する価値があります。
ベストプラクティス
好ましい HTML
<section>
要素を使用すると、アクセス可能な名前が与えられている場合、自動的にセクションがリージョン (region
) ロールを持つことを伝えます。 可能であれば、<section>
を代わりに使用することをお勧めします。
ランドマークのラベル付け
文書に複数のリージョン (region
) ランドマークロールがある場合は、それぞれにラベルを付けます。 このラベルで、支援技術のユーザーがそれぞれのランドマークの目的をすばやく理解することができます。
<div role="region" aria-labelledby="use-discretion">
<h3 id="use-discretion">
慎重に <code>region</code> ロールを使用してください
</h3>
<!-- コンテンツ -->
</div>
...
<div role="region" aria-labelledby="please-reconsider">
<h3 id="please-reconsider">文書構造を再検討してください</h3>
<!-- コンテンツ -->
</div>
この例では、リージョンのラベルは aria-labelledby
属性によって作成されています。
オーバーフローテキストを含むコンテンツ領域のスクロール
tabindex="0"
のコンテンツ領域がある場合は、role="region"
を追加して、汎用のリージョンであるとスクリーンリーダーのユーザーに伝えます。 これは、キーボードのみのユーザーがオーバーフローテキストを含むリージョンをスクロールできるようにするためです。
SVG
SVG の個々のセクションを説明できるようにするために、SVG の領域上に role="region"
を aria-label
とともに宣言することができます。
追加された利点
ブラウザー拡張などの特定の技術は、ページ上に存在する全てのランドマークロールのリストを生成することができ、非スクリーンリーダーユーザーは文書の大きなセクションを素早く識別してナビゲートできます。
- ランドマークブラウザー拡張(英語)
仕様書
Specification |
---|
Accessible Rich Internet Applications (WAI-ARIA) # region |
Unknown specification |
スクリーンリーダーのサポート
TBD
関連情報
<section>
: 汎用セクション要素- region (role): Accessible Rich Internet Applications (WAI-ARIA) 1.1
- HTML のセクションとアウトラインの使用
- ランドマークロール: ARIA を使用する: ロール、ステート、プロパティ
- Using WAI-ARIA Landmarks – 2013 | The Paciello Group
- Accessible Landmarks | scottohara.me
- The section element | HTML5 Doctor
- WAI-ARIA ロール
alertdialog ロールの使用
ARIA: alert ロール
ARIA: application ロール
ARIA: article ロール
ARIA: banner ロール
ARIA: button ロール
ARIA: cell ロール
ARIA: checkbox ロール
ARIA: complementary ロール
ARIA: contentinfo ロール
ARIA: dialog ロール
ARIA: document ロール
ARIA: feed ロール
ARIA: figure ロール
ARIA: form ロール
ARIA: generic ロール
ARIA: grid ロール
ARIA: gridcell ロール
ARIA: heading ロール
ARIA: list ロール
ARIA: listbox ロール
ARIA: listitem ロール
ARIA: main ロール
ARIA: navigation ロール
ARIA: none ロール
ARIA: option ロール
ARIA: radio ロール
ARIA: region ロール
ARIA: row ロール
ARIA: rowgroup ロール
ARIA: search ロール
ARIA: spinbutton ロール
ARIA: switch ロール
ARIA: tab ロール
ARIA: table ロール
ARIA: term ロール
ARIA: textbox ロール
ARIA: tooltip ロール
group ロールの使用
link ロールの使用
log ロールの使用
presentation ロールの使用
progressbar ロールの使用
slider ロールの使用
status ロールの使用
toolbar ロールの使用