コンテンツの非表示と更新

支援技術からコンテンツを非表示にする

Alice Boxhall
Alice Boxhall
Dave Gash
Dave Gash
Meggin Kearney
Meggin Kearney

支援技術のユーザーのエクスペリエンスを微調整するためのもう一つの重要な手法は、ページの関連性のある部分のみを補助技術に開示させることです。DOM の一部をユーザー補助機能 API から参照できないようにする方法はいくつかあります。

まず、DOM に対して明示的に非表示の要素は、アクセシビリティ ツリーにも含まれません。したがって、CSS スタイルが visibility: hidden または display: none の要素、または HTML5 の hidden 属性を使用している要素も、支援技術ユーザーに対して非表示になります。

ただし、視覚的にレンダリングされていなくても、明示的に非表示になっていない要素は依然としてアクセシビリティ ツリーに含まれます。よく使われるのは、絶対位置で画面外に配置された要素に「スクリーン リーダー限定テキスト」を含める方法です。

.sr-only {
    position: absolute;
    left: -10000px;
    width: 1px;
    height: 1px;
    overflow: hidden;
}

また、すでに説明したように、通常は非表示になっている要素を参照する aria-labelaria-labelledby、または aria-describedby 属性を使用して、スクリーン リーダー専用のテキストを指定することもできます。

「スクリーン リーダーのみ」のテキストの作成について詳しくは、テキストを非表示にする手法に関する WebAIM の記事をご覧ください。

最後に、ARIA は、aria-hidden 属性を使用して、視覚的に隠されていないコンテンツを支援技術から除外するためのメカニズムを提供します。この属性を要素に適用すると、アクセシビリティ ツリーから効果的に要素とその子孫を削除できます。ただし、aria-labelledby 属性または aria-describedby 属性によって参照される要素は唯一の例外です。

<div class="deck">
    <div class="slide" aria-hidden="true">
    Sales Targets
    </div>
    <div class="slide">
    Quarterly Sales
    </div>
    <div class="slide" aria-hidden="true">
    Action Items
    </div>
</div>

たとえば、メイン ページへのアクセスをブロックするモーダル UI を作成する場合は、aria-hidden を使用します。この場合、視覚に障がいのないユーザーは、ほとんどのページが現在使用できないことを示す半透明のオーバーレイなどを見ることができますが、スクリーン リーダーのユーザーはそのまま、ページ内のその他の部分にアクセスする可能性があります。この場合、前述のキーボード トラップを作成するだけでなく、ページで現在スコープ外となっている部分も aria-hidden にする必要があります。

これで、ARIA を使用してネイティブ HTML セマンティクスを調整する方法、アクセシビリティ ツリーに大幅な変更を加える方法、1 つの要素のセマンティクスを変更する方法など、ARIA の基本について理解できました。続いて、緊急性の高い情報を伝えるために ARIA を活用するための方法について説明します。

aria-live

aria-live を使用すると、ページの一部に「live」マークを付けることができます。これは、ユーザーがページ上で更新された場所にたまたまアクセスするまで待つのではなく、ページのどこを参照していても最新情報を即座にユーザーに伝える必要があることを意味します。要素に aria-live 属性が指定されていると、その要素を含むページの部分とその子孫はライブ領域と呼ばれます。

ARIA live はライブ リージョンを確立します。

たとえば、ユーザーのアクションの結果として表示されるステータス メッセージなどがライブ領域にあたります。視覚に障がいのないユーザーに注意を喚起するほど重要なメッセージであれば、aria-live 属性を設定して支援技術のユーザーにも注意を促すことが重要です。単純な div は次のとおりです。

<div class="status">Your message has been sent.</div>

"live" を指定した場合と比較してみましょう。

<div class="status" aria-live="polite">Your message has been sent.</div>

aria-live に指定できる値は politeassertiveoff の 3 つです。

  • aria-live="polite" は、実行中の処理がすべて終了したときにユーザーにこの変更を警告するよう支援技術に指示します。重要ではあるものの緊急ではない場合に有用です。また、aria-live の大部分を占めています。
  • aria-live="assertive" は、実行内容をすべて中断し、この変更を直ちにユーザーに警告するよう支援技術に指示します。この値は、重要かつ急を要する更新にのみ使用します。たとえば、「サーバーエラーが発生しました。変更は保存されていません。ページを更新してください」というステータス メッセージを表示したり、ユーザーの操作を直接反映して入力フィールドを更新する場合などが該当します。
  • aria-live="off" は、aria-live の割り込みを一時的に中断するように支援技術に指示します。

ライブ領域を適切に機能させるには、いくつかコツがあります。

まず、aria-live 領域は、最初のページの読み込みで設定する必要があります。これは厳格なルールではありませんが、aria-live 領域で問題が発生した場合は、これが原因である可能性があります。

2 番目に、スクリーン リーダーはそれぞれ、変更の種類に応じて反応が異なります。たとえば、一部のスクリーン リーダーでは、子孫要素の hidden スタイルを true から false に切り替えることで、アラートをトリガーできます。

aria-live と連動するその他の属性を使えば、ライブ領域が変更されたときにユーザーに伝える内容を細かく調整できます。

aria-atomic は、更新を伝えるときに領域全体を 1 つのまとまりと見なすように指定します。たとえば、日、月、年で構成される日付ウィジェットで aria-live=truearia-atomic=true を指定し、ユーザーがステッパー コントロールで月だけを変更した場合は、日付ウィジェットのコンテンツ全体がもう一度読み上げられます。aria-atomic の値は true または false(デフォルト)です。

aria-relevant は、ユーザーに表示する変更のタイプを示します。複数のオプションがあり、個別に、またはトークンリストとして使用できます。

  • additions: ライブ領域に追加するすべての要素に意味があることを意味します。たとえば、既存のステータス メッセージのログに span を追加すると、その span についてユーザーに知らせるということになります(aria-atomicfalse とします)。
  • text: 子孫ノードに追加されるテキスト コンテンツに関連することを意味します。たとえば、カスタム テキスト フィールドの textContent プロパティを変更すると、変更されたテキストがユーザーに読み上げられます。
  • removals: テキストまたは子孫ノードの削除についてユーザーに伝える必要があることを意味します。
  • all: すべての変更が関連することを意味します。ただし、aria-relevant のデフォルト値は additions text です。つまり、aria-relevant を指定しない場合、要素に追加されたものはすべてユーザーに通知されます。これは多くの場合、目的に合致しています。

最後に、aria-busy を使用すると、たとえばなにかを読み込んでいるときなどに、一時的に要素への変更を無視するように支援技術に指示できます。すべてが配置されたら、aria-busy を false に設定し、リーダーを通常の動作に戻す必要があります。