アクセシビリティの高いレスポンシブ デザイン

ご存知のとおり、さまざまな端末で最高のエクスペリエンスを実現するにはレスポンシブ デザインの採用が推奨されますが、レスポンシブ デザインはユーザー補助機能の面でも優れています。

Udacity のようなサイトを例にとって考えてみましょう。

Udacity のサイト

小さな印字を読み取るのが難しい視覚障害のある方はページをズームすることがあり、最大倍率は 400% に及ぶ場合があります。サイトがレスポンシブにデザインされていれば、UI 自体が「小さいビューポート」(つまり大きく表示されたページ)に合わせて再配置するため、画面の拡大が必要なデスクトップ ユーザーやモバイルのスクリーン リーダーのユーザーにとっても読みやすくなり、双方にメリットがあります。 同じページを 400% に拡大したのが次の画像です。

Udacity のサイトがズームを 400% にまで拡大しました

実際、レスポンシブにデザインすると、WebAIM チェックリストのルール 1.4.4 で定義された「テキストのサイズは 2 倍にしても読むことができ、機能できるようにする必要がある」という要件を満たすことができます。

レスポンシブ デザイン全般についてはこのガイドの範囲外なので省略しますが、レスポンシブな処理に役立ち、ユーザーがコンテンツに快適にアクセスできるようにするための重要なポイントをいくつか紹介します。

ビューポート メタタグを使用する

<meta name="viewport" content="width=device-width, initial-scale=1.0">

width=device-width と設定すると、デバイス非依存ピクセルで画面の幅に合わせられます。initial-scale=1 と設定すると、CSS ピクセルとデバイス非依存ピクセルが 1:1 の関係になります。これにより、ブラウザでコンテンツを画面サイズに適合させるため、ユーザーは小さく見づらいテキストに悩まされずに済みます。

詳しくは、コンテンツのサイズをビューポートに合わせるをご覧ください。

ユーザーがズームできるようにする

ビューポート メタタグを使用して、maximum-scale=1 または user-scaleable=no を設定することで、ズームを防止できます。このようなことはせず、必要に応じてユーザーが拡大できるようにしてください。

柔軟な設計

特定の画面サイズをターゲットに設定せず、柔軟なグリッドを使用して、コンテンツに応じてレイアウトを変更します。上記の Udacity の例で説明したように、このアプローチでは、画面が小さい場合でもズームレベルが高い場合でも、スペースが減った場合にデザインが適切に応答します。

これらの手法について詳しくは、レスポンシブ ウェブ デザインの基本の記事をご覧ください。

テキストに相対単位を使用する

フレキシブル グリッドを最大限に活用するには、テキスト サイズなどの要素にピクセル値ではなく、em や rem などの相対単位を使用します。一部のブラウザは、ユーザー プリファレンスでテキストのサイズ変更のみをサポートしています。テキストにピクセル値を使用している場合、この設定はコピーに反映されません。ただし、全体で相対単位を使用していた場合、サイトのコピーはユーザーの設定を反映するように更新されます。

これにより、ユーザーがズームするとサイト全体が再フローをし、サイトの使用に必要な読みやすさを実現できます。

ソースの順序からビジュアル ビューを切断しないようにする

キーボードでサイトをタブ移動する訪問者は、HTML ドキュメント内のコンテンツの順序に沿って移動します。FlexboxGrid などの最新のレイアウト メソッドを使用すると、ビジュアル レンダリングがソース順序と一致しなくなることがよくあります。これにより、キーボードを使ってページを移動する際に、混乱を生じさせてしまう可能性があります。

コンテンツをタブで確認して各ブレークポイントでデザインをテストしてください。ページ全体のフローは適切ですか?

詳しくは、ソースと映像ディスプレイの接続が切断されるをご覧ください。

空間的な手がかりに注意する

マイクロコピーを書くときは、ページ上の要素の位置を示す表現は避けてください。たとえば、ナビゲーションが画面上部にあるモバイル バージョンで「左側」のナビゲーションを参照しても意味がありません。

タッチスクリーン デバイスでタップ ターゲットが十分な大きさであることを確認する

タッチスクリーン デバイスでは、タップ ターゲットを十分な大きさに設定し、他のリンクをタップせずに簡単に有効にできるようにします。タップ可能な要素に適したサイズは 48 px です。タップ ターゲットに関するガイダンスをご覧ください。