アクセシブルなダイアログに必要なこと

  • モーダル要素に role="dialog"aria-modal="true" 属性を付与する
  • モーダル要素に aria-labelledbyaria-describedby 属性を付与する
  • キーボード操作を JavaScript で管理する

モーダル要素に role="dialog"aria-modal="true" 属性を付与する

dialog ロール はウェブアプリケーションやウェブページのプライマリウィンドウの上に重なるダイアログをマークアップするために使用します。ダイアログは通常、オーバレーを使用してプライマリウィンドウの上に配置されます。ダイアログはダイアログ外のコンテンツともやりとり可能なノンモーダルと、ダイアログ内のコンテンツのみとやりとり可能なモーダルの 2 つに分類されます。

alertdialog ロールはユーザーの注意を身近重要なメッセージにそらすダイアログのために特別に設計されたダイアログロールです。

 dialog ロールでマークアップすると支援技術がダイアログのコンテンツをページコンテンツの残りの部分からグループ化けして識別するのに役立ちます。だたし、role="dialog" を追加するだけでは不十分です。以下の冒頭に上げたその他の要件も満たす必要があります。

ダイアログがモーダルである場合、dialog ロールとともに aria-modaltrue に設定する必要があります。aria-modal 属性は表示されちえる要素がモーダルであるかどうか示す属性です。 aria-modal="true" を付与すると支援技術がページ上の他のコンテンツと対話したりアクセスしたりするには、モーダルダイアログを閉じるかフォーカスを失う必要があることをユーザーに知らせるように支援技術者に指示します。これはモーダルが表示されているとき、モーダル要素以外に aria-hidden="true" を付与することと同じ役割を持ちます。

ただし、aria-modeal に対応していないスクリーンリーダーのために aria-hiddenaria-modal どちらも指定しておくのが無難です。

モーダルはその子孫要素だけを使って制御する必要があります。つまり「閉じるボタン」などモーダルを閉じるための要素は aria-modal 属性を付与した DOM の中に存在する必要があります。

ノンモーダルなダイアログには aria-modale を含まないようにします。

モーダル要素に aria-labelledbyaria-describedby 属性を付与する

どのモーダルが表示されているか支援技術に伝えるために、ダイアログにラベルを付与する必要があります。ダイアログにタイトルが表示されている場合には aria-labbeledby 属性を使用してダイアログにラベルを付けることができます。ダイアログにタイトルが存在しない場合には aria-label 属性を使用してラベル付けします。

さらに、ダイアログがタイトル以外の説明テキストを含んでいる場合、aira-describedby 属性を使用してダイアログに関連付けることができます。

キーボード操作

ダイアログはキーボードのフォーカス管理について特有の要件があり、JavaScript を使用してフォーカスを管理する必要があります。

  • ダイアログは 1 つ以上のフォーカス可能な要素を持つべき

  • ダイアログが画面に表示されたら、キーボードのフォーカスを、ダイアログ内のデフォルトのフォーカス可能なコントロールに移動する

    • Tab キーを押したら次のフォーカス可能な要素に移動する。ダイアログ内の最後のフォーカス可能な要素にフォーカスがある場合、ダイアログ内の最初のフォーカス可能な要素にフォーカスを移動する
    • Tab + Shift キーを押したら前のフォーカス可能な要素に移動する。ダイアログ内の最初のフォーカス可能な要素にフォーカスがある場合、ダイアログ内の最後のフォーカス可能な要素に移動する
  • ダイアログが閉じられた後、キーボードフォーカスは、ダイアログに移動する前の位置に戻す

  • ダイアログを移動やサイズ変更できる場合、マウスユーザーだけでなくキーボードユーザーもこれらの操作をできる必要がある

  • モーダルダイアログの場合、ダイアログ外の要素にフォーカスさせない。ノンモーダルダイアログでは、開いているダイアログとメインページの間でフォーカスを移動できるグローバルなキーボードショートカットが必要

  • Escape キーがクリックされたらダイアログを閉じる

参考

Contributors

> GitHub で修正を提案する
この記事をシェアする
Twitterで共有
Hatena

関連記事